# PUD310 8bit OTP Type PD Controller Datasheet Version 0.00 - August 13, 2025 Copyright $\circledcirc$ 2025 by PADAUK Technology Co., Ltd., all rights reserved #### IMPORTANT NOTICE PADAUK Technology reserves the right to make changes to its products or to terminate production of its products at any time without notice. Customers are strongly recommended to contact PADAUK Technology for the latest information and verify whether the information is correct and complete before placing orders. PADAUK Technology products are not warranted to be suitable for use in life-support applications or other critical applications. PADAUK Technology assumes no liability for such applications. Critical applications include, but are not limited to, those which may involve potential risks of death, personal injury, fire or severe property damage. Any programming software provided by PADAUK Technology to customers is of a service and reference nature and does not have any responsibility for software vulnerabilities. PADAUK Technology assumes no responsibility for any issue caused by a customer's product design. Customers should design and verify their products within the ranges guaranteed by PADAUK Technology. In order to minimize the risks in customers' products, customers should design a product with adequate operating safeguards. ## **Table of content** | Re | vision | History | 8 | |----|--------|---------------------------------------------------------------------------------|----| | Us | age W | /arning | 8 | | 1. | Featu | ires | 9 | | | 1.1. | Special Features | 9 | | | 1.2. | Fast Charging Specification Application Features | 9 | | | 1.3. | System Features | 10 | | | 1.4. | CPU Features | 10 | | | 1.5. | Ordering/ Package Information | 10 | | 2. | Gene | ral Description and Block Diagram | 11 | | 3. | Pin D | efinition and Functional Description | 12 | | 4. | Devic | e Characteristics | 15 | | | 4.1. | AC/DC Device Characteristics | 15 | | | 4.2. | Absolute Maximum Ratings | 16 | | | 4.3. | Typical ILRC frequency vs. VDD | 17 | | | 4.4. | Typical IHRC frequency deviation vs. VDD (calibrated to 12MHz) | 17 | | | 4.5. | Typical ILRC Frequency vs. Temperature | 18 | | | 4.6. | Typical IHRC Frequency vs. Temperature (calibrated to 12MHz) | 18 | | | 4.7. | Typical operating current vs. VDD @ system clock = ILRC/n | 19 | | | 4.8. | Typical operating current vs. VDD @ system clock = IHRC/n | 19 | | | 4.9. | Typical IO driving current (Iон) and sink current (Iоь) | 20 | | | 4.10. | Typical IO input high/low threshold voltage (V <sub>IH</sub> /V <sub>IL</sub> ) | 21 | | | 4.11. | Typical resistance of IO Pull High Resistor | 21 | | | 4.12. | Typical resistance of IO Pull Low Resistor | 22 | | | 4.13. | Typical power down current (IPD) and power save current (IPS) | 22 | | | 4.14. | Different VDD Voltage vs. VREG | 23 | | | 4.15. | DP/DM Pin Characteristics | 24 | | | 4.16. | CC1/CC2 Pin Characteristics | 24 | | | 4.17. | GATE Pin Characteristics | 25 | | | 4.18. | VBUS (VDD) Comparator Characteristics | 25 | | 5. | Func | tional Description | 26 | |----|------|-------------------------------------------------------------------|----| | | 5.1. | Program Memory - OTP | 26 | | | 5.2. | Boot Procedure | 26 | | | | 5.2.1. Timing charts for reset conditions | 27 | | | 5.3. | Data Memory - SRAM | 28 | | | 5.4. | Oscillator and Clock | 28 | | | | 5.4.1. Internal High RC oscillator and Internal Low RC oscillator | 28 | | | | 5.4.2. Chip calibration | 29 | | | | 5.4.3. IHRC Frequency Calibration and System Clock | 29 | | | | 5.4.4. System Clock and LVR level | 30 | | | | 5.4.5. System Clock Switching | 31 | | | 5.5 | 16-bit Timer (Timer16) | 32 | | | 5.6 | 8-bit Timer (Timer2) with PWM generation | 33 | | | | 5.6.1 Using the Timer2 to generate periodical waveform | 34 | | | | 5.6.2 Using the Timer2 to generate 8-bit PWM waveform | 36 | | | | 5.6.3 Using the Timer2 to generate 6-bit PWM waveform | 37 | | | | 5.6.4 PWM Waveform | 38 | | | 5.7 | WatchDog Timer | 38 | | | 5.8 | Interrupt | 39 | | | 5.9 | Power-Save and Power-Down | 41 | | | | 5.9.1 Power-Save mode ("stopexe") | 41 | | | | 5.9.2 Power-Down mode ("stopsys") | 42 | | | | 5.9.3 Wake-up | 43 | | | 5.10 | IO Pins | 43 | | | 5.11 | Reset and LVR | 44 | | | | 5.11.1 Reset | 44 | | | | 5.11.2LVR reset | 44 | | | 5.12 | PD PHY Controller | 45 | | | | 5.12.1 Features | 45 | | | | 5.12.2 Block Diagram | 45 | | | | 5.12.3 Function Description | 47 | | | | 5.12.3.1 TX/RX Hardware State Diagram | 47 | | | | 5.12.3.2 TX Flow Control | 48 | | | | 5.12.3.3 RX Flow Control | 50 | | | 5.12.3.4 PD PHY Interrupt Type | . 51 | |-------|-------------------------------------------------------------|------| | | 5.12.3.5 TX/RX FIFO Access | . 52 | | | 5.12.3.6 CRC32 Features | . 52 | | | 5.12.3.7 TX and RX Collision Process | . 52 | | | 5.12.3.8 Received Signal Quality Adjustment | . 53 | | | 5.12.3.9 Internal and External Loopback Mode | . 53 | | | 5.12.3.10 Inner Hardware Signal Probe | . 53 | | | 5.12.4 Programming Sequence | . 54 | | | 5.12.4.1 Transmit one SOP Packet | . 54 | | | 5.12.4.2 Transmit one Hard Reset Signaling | . 55 | | | 5.12.4.3 Receive one SOP Packet | . 55 | | | 5.12.4.4 Receive one Hard Reset Signaling | . 55 | | | 5.12.4.5 Transmit the BIST Signaling | . 56 | | | 5.12.4.6 Internal and External Loopback Testing | . 56 | | | 5.12.4.7 CC Wire Manual Control | . 57 | | 5.13 | Analog Front End (DP/DM/CC1/CC2) | . 58 | | | 5.13.1 Features | . 58 | | | 5.13.2 Block Diagram | . 59 | | | 5.13.3 Function Description | . 60 | | | 5.13.3.1 DP and DM Output Control | . 60 | | | 5.13.3.2 DP and DM Input Control | . 61 | | | 5.13.3.3 DP and DM GPIO Control Mode | . 62 | | | 5.13.3.4 CC1 and CC2 Control | . 65 | | | 5.13.3.4.1 USB PD Data Stream Path | . 66 | | | 5.13.3.4.2 USB Type-C 5V/1.5A and 5V/3A Detection | . 66 | | | 5.13.3.4.3 CC1/CC2 Attached Detection | . 66 | | 5.14 | GATE Pin Control and Connection | . 67 | | | 5.14.1 Function Description | . 67 | | | 5.14.2 GATE Pin Application Connection | . 68 | | 5.15 | VBUS (VDD) Voltage Comparator | . 68 | | | 5.15.1 Function Description | . 68 | | IO Re | gisters | . 69 | | 6.1. | ACC Status Flag Register ( <i>flag</i> ), IO address = 0x00 | . 69 | | 6.2. | Reset Control Register ( <i>rstc</i> ), IO address = 0x01 | . 69 | | | | | 6. | 6.3. | Stack Pointer Register ( <i>sp</i> ), IO address = 0x02 | 69 | |-------|------------------------------------------------------------------|----| | 6.4. | Clock Mode Register ( <i>clkmd</i> ), IO address = 0x03 | 70 | | 6.5. | Interrupt Enable Register ( <i>inten</i> ), IO address = 0x04 | 70 | | 6.6. | Interrupt Request Register (intrq), IO address = 0x05 | 70 | | 6.7. | LVR Reset Control Register (lvrc), IO address = 0x08 | 71 | | 6.8. | Interrupt Edge Select Register (integ), IO address = 0x09 | 71 | | 6.9. | Timer16 mode Register ( <i>t16m</i> ), IO address = 0x0B | 71 | | 6.10. | DP/DM IO Control Register (dp_dm_io_ctrl), IO address = 0x0C | 72 | | 6.11. | Port A Digital Input Enable Register (padier), IO address = 0x0D | 73 | | 6.12. | Port B Digital Input Enable Register (pbdier), IO address = 0x0E | 74 | | 6.13. | Port A Data Register (pa), IO address = 0x10 | 74 | | 6.14. | Port A Control Register (pac), IO address = 0x11 | 74 | | 6.15. | Port A Pull-High Register (paph), IO address = 0x12 | 74 | | 6.16. | Port A Pull-Low Register (papl), IO address = 0x13 | 74 | | 6.17. | Port B Data Register (pb), IO address = 0x14 | 74 | | 6.18. | Port B Control Register (pbc), IO address = 0x15 | 74 | | 6.19. | Port B Pull-High Register (pbph), IO address = 0x16 | 75 | | 6.20. | Port B Pull-Low Register (pbpl), IO address = 0x17 | 75 | | 6.21. | Timer2 PWM Control Register ( <i>tpw2c</i> ), IO address = 0x1A | 75 | | 6.22. | Timer2 PWM Scalar Register (tpw2s), IO address = 0x1B | 76 | | 6.23. | Timer2 PWM Bound Register ( <i>tpw2b</i> ), IO address = 0x1C | 76 | | 6.24. | Operation Register (opr1), IO address = 0x1D | 76 | | 6.25. | Miscellaneous Register ( <i>misc2</i> ), IO address = 0x1F | 76 | | 6.26. | PD PHY FIFO Register (pd_fifo), IO address = 0x30 | 77 | | 6.27. | PD PHY Status Register ( <i>pd_stat</i> ), IO address = 0x31 | 77 | | 6.28. | PD PHY TXRX Register (pd_txrx), IO address = 0x32 | 78 | | 6.29. | PD PHY Control Register ( <i>pd_ctrl</i> ), IO address = 0x33 | 79 | | 6.30. | PD PHY Decoder Register (pd_decoder), IO address = 0x34 | 80 | | 6.31. | DP Output Register ( <i>dp_out</i> ), IO address = 0x38 | 81 | | 6.32. | DP Input Register (dp_in), IO address = 0x39 | 82 | | 6.33. | DM Output Register (dm_out), IO address = 0x3A | 82 | | 6.34. | DM Input Register (dm_in), IO address = 0x3B | 83 | | 6.35. | CC Control Register ( <i>cc_ctrl</i> ), IO address = 0x3D | 83 | | 6.36. | CC Status Register ( <i>cc_stat</i> ), IO address = 0x3E | 84 | | | 6.37. | CC Miscellaneous Register ( <i>cc_misc</i> ), IO address = 0x3F | 84 | |----|--------|-----------------------------------------------------------------|-----| | 7. | Instru | ıctions | 85 | | | 7.1. | Data Transfer Instructions | 86 | | | 7.2. | Arithmetic Operation Instructions | 88 | | | 7.3. | Shift Operation Instructions | 90 | | | 7.4. | Logic Operation Instructions | 91 | | | 7.5. | Bit Operation Instructions | 93 | | | 7.6. | Conditional Operation Instructions | 94 | | | 7.7. | System Control Instructions | 95 | | | 7.8. | Summary of Instructions Execution Cycle | 97 | | | 7.9. | Summary of affected flags by Instructions | 97 | | | 7.10. | BIT definition | 98 | | 8. | Code | Options | 98 | | 9. | Speci | ial Notes | 98 | | | 9.1. | Using IC | 98 | | | | 9.1.1. IO pin usage and setting | 98 | | | | 9.1.2. Interrupt | 99 | | | | 9.1.3. System clock switching | 99 | | | | 9.1.4. Watchdog | 99 | | | | 9.1.5. TIMER time out | 100 | | | | 9.1.6. IHRC | 100 | | | | 9.1.7. LVR | 100 | | | | 9.1.8 Programming Writing | 101 | ## **Revision History** | Revision | Date | Description | |----------|------------|----------------------| | 0.00 | 2025/08/13 | Preliminary version. | ## **Usage Warning** User must read all application notes of the IC by detail before using it. Please visit the official website to download and view the latest APN information associated with it. https://www.padauk.com.tw/en/product/search\_list.aspx?kw=PUD #### 1. Features #### 1.1. Special Features - ◆ General purpose series - ◆ USB Power Delivery (PD) Sink application - ◆ USB Battery Charging 1.2 (BC1.2) detection - ◆ This product can display multiple breathing light modes - ◆ Operating temperature range: -40°C ~ 85°C #### 1.2. Fast Charging Specification Application Features - Particular USB DP and DM pins can support different charging specification applications: - (1) Selective drive voltage level: 5.0V, 3.3V, 0.6V, 0V - (2) Selective voltage comparator: 3.0V, 2.4V, 1.2V, 0.35V - (3) 13V high voltage tolerance - (4) Can be configured as OTP download cable pins at test mode - ◆ Particular USB CC1 and CC2 pins can support USB PD specification application: - (1) One USB PD PHY transceiver - (2) One 0.66V voltage comparator for USB Type-C 5V/1.5A detection - (3) One 1.23V voltage comparator for USB Type-C 5V/3A detection - (4) Precise 1.125V CC1/CC2 drive voltage - (5) 21V high voltage tolerance - ◆ One digital PD PHY controller can support USB PD specification application - One particular GATE pin can be connected to external power MOSFET to turn on/off power line: - (1) Open-drain IO (20mA sink current at $V_{OL} = 0.5V$ ) - (2) 21V high voltage tolerance - ♦ One VBUS (VDD) 7V voltage comparator for charging specification application - ◆ 4V ~ 21V VBUS (VDD) work voltage range #### 1.3. System Features - ◆ 1.5KW OTP program memory - 96 Bytes data RAM - One hardware 16-bit timer - ◆ One hardware 8-bit timers with 6/7/8-bit PWM generation - ◆ 5 IO pins with optional pull-high and pull-low resistor (PA0, PA3, PA5, PB0, PB1) - ◆ Three different IO Driving capability group to meet different application requirements - (1) PA4, PA6 Drive/ Sink Current= 0.33mA / 0.37mA - (2) Other IOs (except PA7) Drive/ Sink Current = 16mA / 18mA - ◆ Every IO pin (except PA4 & PA6) can be configured to enable wake-up function - ◆ Clock sources: IHRC, ILRC & NILRC - For every wake-up enabled IO, two optional wake-up speed are supported: normal and fast - ◆ 16 levels of LVR: - 4.5V, 4.0V, 3.75V, 3.5V, 3.3V, 3.15V, 3.0V, 2.7V, 2.5V, 2.4V, 2.3V, 2.2V, 2.1V, 2.0V, 1.9V, and 1.8V - ◆ One external interrupt pins: PA0 - Bandgap circuit to provide 1.20V reference voltage #### 1.4. CPU Features - One processing unit operating mode - ♦ 95 powerful instructions - Most instructions are 1T execution cycle - ◆ Programmable stack pointer to provide adjustable stack level - Direct and indirect addressing modes for data access. Data memories are available for use as an index pointer of Indirect addressing mode - ◆ IO space and memory space are independent #### 1.5. Ordering/ Package Information - ◆ PUD310-U06A: SOT23-6 (60mil) - ◆ PUD310-2N08A: DFN (2\*2mm) - ◆ PUD310-EY10A: ESSOP10 (150mil) - ◆ PUD310-2N06A: DFN (2\*2mm) - ◆ PUD310-S08A: SOP8 (150mil) - ◆ PUD310-4N12A: DFN (3\*3mm) - Please refer to the official website file for package size information: "Package information " #### 2. General Description and Block Diagram The PUD310 family is an IO-Type, fully static, OTP-based CMOS 8-bit microcontroller. It employs RISC architecture and all the instructions are executed in one cycle except that some instructions are two cycles that handle indirect memory access. 1.5KW bits OTP program memory and 96 bytes data SRAM are inside. PUD310 also provides two hardware timers: one 16-bit timer and one 8-bit timer with PWM generation, refer to Fig. 2.1. Fig. 2.1: PUD310 architecture ### 3. Pin Definition and Functional Description PUD310-U06A: SOT23-6 (60mil) PUD310-S08A: SOP8 (150mil) PUD310-EY10A: ESSOP10 (150mil) PUD310-2N08A: DFN (2\*2mm) PUD310-4N12A: DFN (3\*3mm) | Pin Name | Pin Type & Buffer Type | Description | | | | | | | |-----------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--| | PA7 /<br>GATE | OD<br>HVT | The functions of this pin can be: (1) Used to connect to external power MOSFET to turn on/off power line (PA7 can't be GPIO). High voltage tolerance = 21V. A 20mA sink current at Vol = 0.5V. | | | | | | | | PA6 /<br>DM /<br>TDIO | The functions of this pin can be: (1) USB DM pin (PA6 can't be GPIO). (2) Download cable TDIO pin for OTP program. If this pin is used for download cable pin, it must work at test mode. High voltage tolerance = 13V. | | | | | | | | | PA5 /<br>ERST | IO (OD)<br>ST /<br>CMOS | <ul> <li>The functions of this pin can be:</li> <li>(1) Bit 5 of port A. It can be configured as digital input or open-drain output, with pull-high resistor.</li> <li>(2) Hardware reset.</li> <li>This pin can be used to wake-up system during sleep mode; however, wake-up function is also disabled if bit 5 of <i>padier</i> register is "0". Please put 33Ω resistor in series to have high noise immunity when this pin is in input mode.</li> </ul> | | | | | | | | PA4 /<br>DP /<br>TCLK | IO<br>HVT | The functions of this pin can be: (1) USB DP pin (PA4 can't be GPIO). (2) Download cable TCLK pin for OTP program. If this pin is used for download cable pin, it must work at test mode. High voltage tolerance = 13V. | | | | | | | | PA3 /<br>TM2 | IO<br>ST /<br>CMOS | <ul> <li>The functions of this pin can be:</li> <li>(1) Bit 3 of port A. It can be configured as digital input or two-state output, with pull-high resistor.</li> <li>(2) PWM output from Timer2</li> <li>When this pin is configured as analog input, please use bit 3 of register <i>padier</i> to disable the digital input to prevent current leakage. The bit 3 of <i>padier</i> register can be set to "0" to disable digital input; wake-up from power-down by toggling this pin is also disabled.</li> </ul> | | | | | | | | PA2 / IO<br>CC2 HVT | | The functions of this pin can be: (1) USB CC2 pin (PA2 can't be GPIO). High voltage tolerance = 21V. [NOTE 2] | | | | | | | | PA1 / IO<br>CC1 HVT | | The functions of this pin can be: (1) USB CC1 pin (PA1 can't be GPIO). High voltage tolerance = 21V. [NOTE 2] | | | | | | | | Pin Name Pin Type & Buffer Type | | Description | |---------------------------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | PA0 /<br>EINT | IO<br>ST /<br>CMOS | <ul> <li>The functions of this pin can be:</li> <li>(1) Bit 0 of port A. It can be configured as digital input or two-state output, with pull-high resistor.</li> <li>(2) External interrupt line 0. It can be used as an external interrupt line 0. Both rising edge and falling edge are accepted to request interrupt service and configurable by register setting</li> <li>The bit 0 of <i>padier</i> register can be set to "0" to disable wake-up from power-down by toggling this pin.</li> </ul> | | PB1 | IO<br>ST /<br>CMOS | The functions of this pin can be: Bit 1 of port B. It can be configured as digital input or two-state output, with pull-high resistor. The bit 1 of <i>pbdier</i> register can be set to "0" to disable digital input; wake-up from power-down by toggling this pin is also disabled. | | PB0 | IO<br>ST /<br>CMOS | The functions of this pin can be: Bit 0 of port B. It can be configured as digital input or two-state output, with pull-high resistor. The bit 0 of <i>pbdier</i> register can be set to "0" to disable digital input, wake-up from power-down by toggling this pin is also disabled. | | VDD | VDD | Positive power | | GND | GND | Ground | NOTE 1: IO: Input/Output; ST: Schmitt Trigger input; OD: Open Drain; Analog: Analog input pin CMOS: CMOS voltage level; HVT: High Voltage Tolerance NOTE 2: CC1 and CC2 tolerance is tested per below waveforms. (shown in the Fig. 3.1) - (1) Supply VDD=21V power source at T1. - (2) Supply CC1/CC2=21V power source at T1+30ms, to emulate CC1/CC2 short to VDD (VBUS). - (3) Disable VDD and CC1/CC2 power source at T1+50ms. Per USB PD specification, SOURCE shall disable VBUS within 20ms when detect SINK detached. Fig. 3.1 Test Method for CC1/CC2 Maximum Rating #### 4. Device Characteristics #### 4.1. AC/DC Device Characteristics All data are acquired under the conditions of Ta= -40 $^{\circ}$ C ~ 85 $^{\circ}$ C, V<sub>DD</sub>=5.0V, f<sub>SYS</sub> =3MHz unless noted. | Symbol | Description | Min | Тур | Max | Unit | Conditions (Ta=25°C) | | | |------------------------|--------------------------------------------------------|----------------------|--------------|-------------------------|----------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--| | $V_{DD}$ | Operating Voltage | 4# | | 21 | V | <sup>#</sup> Subject to LVR tolerance | | | | LVR% | Low Voltage Reset Tolerance | -5 | | 5 | % | | | | | fsys | System clock (CLK)* = IHRC/1 IHRC/2 IHRC/4 IHRC/8 ILRC | 0<br>0<br>0<br>0 | 41K | 12M<br>6M<br>3M<br>1.5M | Hz | $\begin{array}{c} V_{DD} \geqq 3.0V \\ V_{DD} \geqq 3.0V \\ V_{DD} \trianglerighteq 3.0V \\ V_{DD} \trianglerighteq 3.0V \\ V_{DD} \trianglerighteq 3.0V \\ V_{DD} = 5.0V \end{array}$ | | | | $V_{POR}$ | Power On Reset Voltage | | 1.8* | | V | * Subject to LVR tolerance | | | | ЮР | Operating Current | | 1.7<br>30 | | mA<br>uA | f <sub>SYS</sub> =IHRC/8 =1.5MIPS@5.0V<br>f <sub>SYS</sub> =ILRC =41KHz@5.0V | | | | IPD | Power Down Current (by <b>stopsys</b> command) | | 0.24<br>0.15 | | uA<br>uA | $f_{SYS}$ =0Hz, $V_{DD}$ =5.0V $f_{SYS}$ =0Hz, $V_{DD}$ =3.3V | | | | I <sub>PS</sub> | Power Save Current (by <b>stopexe</b> command) | | 3.0 | | uA | V <sub>DD</sub> =5.0V; f <sub>SYS</sub> =ILRC<br>Only ILRC module is enabled. | | | | VIL | Input low voltage for IO lines | 0 | | 0.2 V <sub>REG</sub> | V | | | | | VIH | Input high voltage for IO lines | 0.7 V <sub>REG</sub> | | V <sub>REG</sub> | V | | | | | | IO lines sink current | | | | | | | | | loL | PA6, PA4<br>PA5, PA3, PA0, PB1, PB0 | | 0.4<br>17 | | mA | V <sub>DD</sub> =5.0V, V <sub>OL</sub> =0.5V<br>V <sub>DD</sub> =5.0V, V <sub>OL</sub> =0.5V | | | | | IO lines drive current | | | | | | | | | Іон | PA5, PA3, PA0, PB1, PB0<br>PA6, PA4 | | -13<br>-0.15 | | mA | V <sub>DD</sub> =5.0V, V <sub>OH</sub> =4.5V | | | | V <sub>IN</sub> | Input voltage | -0.3 | | V <sub>DD</sub> +0.3 | V | | | | | I <sub>INJ</sub> (PIN) | Injected current on pin | | | 1 | mA | $V_{REG}$ +0.3 $\geq$ $V_{IN}$ $\geq$ -0.3 | | | | R <sub>PH</sub> | Pull-high Resistance | | 75 | | ΚΩ | V <sub>DD</sub> =5.0V | | | | R <sub>PL</sub> | Pull-low Resistance | | 75 | | ΚΩ | V <sub>DD</sub> =5.0V | | | | V <sub>BG</sub> | Bandgap Reference Voltage | 1.145* | 1.20* | 1.255* | V | V <sub>DD</sub> =4.5V ~ 21V<br>-40°C <ta< 85°c*<="" td=""></ta<> | | | | | F | 11.82* | 12* | 12.18* | | 25°C, V <sub>DD</sub> =4.5V~21V | | | | f <sub>IHRC</sub> | Frequency of IHRC after calibration * | 11.40* | 12* | 12.60* | MHz | V <sub>DD</sub> =4.5V~21V,<br>-40°C <ta< 85°c*<="" td=""></ta<> | | | | V <sub>REG</sub> | Regulator output voltage | | 4.55 | | | V <sub>DD</sub> =5.0V | | | | t <sub>INT</sub> | Interrupt pulse width | 30 | | | ns | V <sub>DD</sub> =5.0V | | | | $V_{DR}$ | RAM data retention voltage* | 1.5 | | | V | in stop mode | | | | Symbol | Description | Min | Тур | Max | Unit | Conditions (Ta=25°C) | |------------------|------------------------------------------------------|-----|------|----------------------|-------------------|-------------------------------------| | | | | 8K | | | misc[1:0]=00 (default) | | | Watchdog timeout period | | 16K | | _ | misc[1:0]=01 | | twdt | | | 64K | | TILRC | misc[1:0]=10 | | | | | 256K | | | misc[1:0]=11 | | | Wake-up time period for fast wake-up | | 15 | | <b>T</b> | Where T <sub>ILRC</sub> is the time | | twup | Wake-up time period for slow wake-up | | 1024 | | T <sub>ILRC</sub> | period of ILRC | | t <sub>SBP</sub> | System boot-up period from power-on for Slow boot-up | | 25 | | ms | V <sub>DD</sub> =5.0V | | t <sub>RST</sub> | External reset pulse width | 120 | | | us | @ V <sub>DD</sub> =5.0V | | CPos | Comparator offset* | | ±10 | ±20 | mV | | | CPcm | Comparator input common mode* | 0 | | V <sub>DD</sub> -1.5 | V | | | CPspt | Comparator response time** | | 100 | 500 | ns | Both Rising and Falling | | CPmc | Stable time to change | | 2.5 | 7.5 | us | | | | comparator mode | | | | | | | CPcs | Comparator current consumption | | 20 | | uA | V <sub>DD</sub> = 3.3V | <sup>\*</sup>These parameters are for design reference, not tested for each chip. #### 4.2. Absolute Maximum Ratings | Parameter | Maximum Rating | Notes | |-----------------------|----------------------------------|-----------------------------------------------| | Cumply Voltage (VDD) | 21V | If VDD exceeds this rating, it may lead to | | Supply Voltage (VDD) | 210 | permanent damage to the IC. | | CATE Voltage | 21V | If GATE is forced to the maximum rating, it | | GATE Voltage | 210 | may lead to permanent damage to the IC. | | | | Maximum rating tested per Figure 3.1. | | CC1, CC2 Voltage | 21V | Overstress in voltage (21V) or time (20ms) | | | | may cause permanent damage. | | DP, DM Voltage | 13V | If DP or DM are forced to the maximum rating, | | DP, DIVI VOITage | 130 | it may lead to permanent damage to the IC. | | Maximum CLOAD | | If CC1 or CC2 are loaded with total | | on CC1/CC2 | 1.4nF | capacitance more than 1.4nF, it may cause | | 011 CC 1/CC2 | | USB PD transaction failure. | | Input Voltage Bange | -0.3V ~ V <sub>REG</sub> + 0.3V | Exceeding this range may cause device | | Input Voltage Range | -0.3V ~ V\\$ub>REG\/\$ub> + 0.3V | damage. | | Operating Temperature | -40°C ~ 85°C | | | Storage Temperature | -50°C ~ 125°C | | | Junction Temperature | 150°C | | #### 4.3. Typical ILRC frequency vs. VDD #### 4.4. Typical IHRC frequency deviation vs. VDD (calibrated to 12MHz) #### 4.5. Typical ILRC Frequency vs. Temperature #### 4.6. Typical IHRC Frequency vs. Temperature (calibrated to 12MHz) #### 4.7. Typical operating current vs. VDD @ system clock = ILRC/n Conditions: ON: Bandgap, LVR, ILRC; OFF: IHRC, T16, TM2; IO: PA0:0.5Hz output toggle and no loading, others: input and no floating #### 4.8. Typical operating current vs. VDD @ system clock = IHRC/n Conditions: **ON**: Bandgap, LVR, IHRC; **OFF**: ILRC, T16, TM2; IO: PA0:0.5Hz output toggle and no loading, others: input and no floating #### 4.9. Typical IO driving current (Iон) and sink current (IоL) (VOH=0.9\*VDD, VOL=0.1\*VDD) #### 4.10. Typical IO input high/low threshold voltage (VIH/VIL) #### 4.11. Typical resistance of IO Pull High Resistor #### 4.12. Typical resistance of IO Pull Low Resistor #### 4.13. Typical power down current (IPD) and power save current (IPS) #### 4.14. Different VDD Voltage vs. VREG #### 4.15. DP/DM Pin Characteristics Conditions: ON: Bandgap, LVR, IHRC; OFF: ILRC, T16 All data are acquired under the conditions of Ta= 25 °C, V<sub>DD</sub>=5.0V, f<sub>SYS</sub> =12MHz unless noted. | Symbol | Description | Min | Тур | Max | Unit | Conditions (Ta=25°C) | |----------------------|-------------------------------|------|--------------------|------|------|-------------------------------------------------------------------------| | V <sub>ODP5</sub> | DP 5V Drive Voltage | 4.0 | V <sub>REG</sub> * | 5.0 | V | CP Test Range<br>See section 4.14 Different VDD vs.<br>V <sub>REG</sub> | | V <sub>ODP3.3</sub> | DP 3.3V Drive Voltage | 3.0 | 3.3 | 3.6 | V | CP Test Range | | V <sub>ODP0.6</sub> | DP 0.6V Drive Voltage | 0.5 | 0.6 | 0.7 | V | CP Test Range | | V <sub>ODP0</sub> | DP 0V Drive Voltage | 0.0 | | 0.1 | V | CP Test Range | | V <sub>IDP3</sub> | DP Comparator 3V Threshold | 2.7 | 3.0 | 3.3 | V | CP Test Range | | V <sub>IDP2.4</sub> | DP Comparator 2.4V Threshold | 2.0 | 2.4 | 2.7 | V | CP Test Range | | V <sub>IDP1.2</sub> | DP Comparator 1.2V Threshold | 1.08 | 1.2 | 1.32 | V | CP Test Range | | V <sub>IDP0.35</sub> | DP Comparator 0.35V Threshold | 0.25 | 0.35 | 0.40 | V | CP Test Range | | V <sub>ODM5</sub> | DM 5V Drive Voltage | 4.0 | V <sub>REG</sub> * | 5.0 | V | CP Test Range<br>See section 4.14 Different VDD vs.<br>V <sub>REG</sub> | | V <sub>ODM3.3</sub> | DM 3.3V Drive Voltage | 3.0 | 3.3 | 3.6 | V | CP Test Range | | V <sub>ODM0.6</sub> | DM 0.6V Drive Voltage | 0.5 | 0.6 | 0.7 | V | CP Test Range | | V <sub>ODM0</sub> | DM 0V Drive Voltage | 0.0 | | 0.1 | V | CP Test Range | | V <sub>IDM3</sub> | DM Comparator 3V Threshold | 2.7 | 3.0 | 3.3 | V | CP Test Range | | V <sub>IDM2.4</sub> | DM Comparator 2.4V Threshold | 2.0 | 2.4 | 2.7 | V | CP Test Range | | V <sub>IDM1.2</sub> | DM Comparator 1.2V Threshold | 1.08 | 1.2 | 1.32 | V | CP Test Range | | V <sub>IDM0.35</sub> | DM Comparator 0.35V Threshold | 0.25 | 0.35 | 0.40 | V | CP Test Range | <sup>\*</sup>This parameter is subject to Regulator output voltage (VREG). #### 4.16. CC1/CC2 Pin Characteristics Conditions: ON: Bandgap, LVR, IHRC; OFF: ILRC, T16 All data are acquired under the conditions of Ta= 25 °C, V<sub>DD</sub>=5.0V, f<sub>SYS</sub> =12MHz unless noted. | Symbol | Description | Min | Тур | Max | Unit | Conditions (Ta=25°C) | |---------------------|-------------------------------|-------------------------------|-------|------|------|----------------------| | V <sub>OHCC1</sub> | CC1 1.125V Drive Voltage | 1.05 | 1.125 | 1.20 | V | CP Test Range | | V <sub>OLCC1</sub> | CC1 0V Drive Voltage | C1 0V Drive Voltage 0.0 0.1 V | | | | CP Test Range | | V <sub>ATTCC1</sub> | CC1 Comparator 0.2V Threshold | 0.15 | 0.20 | 0.25 | V | CP Test Range | | V <sub>OHCC2</sub> | CC2 1.125V Drive Voltage | 1.05 | 1.125 | 1.20 | V | CP Test Range | | V <sub>OLCC2</sub> | CC2 0V Drive Voltage | 0.0 | | 0.1 | V | CP Test Range | | V <sub>ATTCC2</sub> | CC2 Comparator 0.2V Threshold | 0.15 | 0.20 | 0.25 | V | CP Test Range | | V <sub>1.5ACC</sub> | CC Comparator 0.66V Threshold | 0.61 | 0.66 | 0.70 | V | CP Test Range | | V <sub>3ACC</sub> | CC Comparator 1.23V Threshold | 1.16 | 1.23 | 1.31 | V | CP Test Range | #### 4.17. GATE Pin Characteristics Conditions: ON: Bandgap, LVR, IHRC; OFF: ILRC, T16 All data are acquired under the conditions of Ta= 25 °C, V<sub>DD</sub>=5.0V, f<sub>SYS</sub> =12MHz unless noted. | Symbol | Description | Min | Тур | Max | Unit | Conditions (Ta=25°C) | |-------------------|---------------------------|------|-----|------|------|------------------------------------------------------| | Volgate | GATE 0V Drive Voltage | 0.00 | | 0.10 | V | GATE connect a 31.5k resistor to 10V (CP Test Range) | | Vohgate | GATE Floating Output Test | 9.5 | | 10 | V | GATE connect a 31.5k resistor to 10V (CP Test Range) | | Vohgate | GATE Floating Output Test | 21.5 | | 22 | V | GATE connect a 55k resistor to 22V (Laboratory Test) | | I <sub>GATE</sub> | GATE Sink Current | | | 20 | mA | At V <sub>OL</sub> = 0.5V<br>(Laboratory Test) | #### 4.18. VBUS (VDD) Comparator Characteristics Conditions: ON: Bandgap, LVR, IHRC; OFF: ILRC, T16 All data are acquired under the conditions of Ta= 25 °C, V<sub>DD</sub>=5.0V, f<sub>SYS</sub> =12MHz unless noted. | Symbol | Description | Min | Тур | Max | Unit | Conditions (Ta=25°C) | |-------------------|------------------------------|-----|-----|-----|------|----------------------| | V <sub>VBUS</sub> | VBUS Comparator 7V Threshold | 6.5 | 7.0 | 7.5 | > | CP Test Range | #### 5. Functional Description #### 5.1. Program Memory - OTP The OTP (One Time Programmable) program memory is used to store the program instructions to be executed. The OTP program memory may contain the data, tables and interrupt entry. After reset, the initial address 0x000 is reserved for system using, so the program will start from 0x001 which is GOTO FPPA0 instruction usually. The interrupt entry is 0x10 if used, the last 16 addresses are reserved for system using, like checksum, serial number, etc. The OTP program memory for PUD310 is 1.5KW that is partitioned as Table 5.1. The OTP memory from address '0x5F0 to 0x5FF is for system using, address space from0x002 to 0x00F and from 0x011 to 0x5EF are user program spaces. | Address | Function | |---------|-------------------------| | 0x000 | System Using | | 0x001 | GOTO FPPA0 instruction | | 0x002 | User program | | • | • | | 0x00F | User program | | 0x010 | Interrupt entry address | | 0x011 | User program | | • | • | | 0x5EF | User program | | 0x5F0 | System Using | | • | • | | 0x5FF | System Using | Table 5.1: Program Memory Organization #### 5.2. Boot Procedure POR (Power-On-Reset) is used to reset PUD310 when power up. The boot up time is about 1024 ILRC clock cycles. Customer must ensure the stability of supply voltage after power up, the power up sequence is shown in the Fig. 5.1 and $t_{\text{SBP}}$ is the boot up time. Please noted, during Power-On-Reset, the V<sub>DD</sub> must go higher than V<sub>POR</sub> to boot-up the MCU. Fig. 5.1: Power-Up Sequence #### 5.2.1. Timing charts for reset conditions #### 5.3. Data Memory - SRAM The access of data memory can be byte or bit operation. Besides data storage, the SRAM data memory is also served as data pointer of indirect access method and the stack memory. The stack memory is defined in the data memory. The stack pointer is defined in the stack pointer register; the depth of stack memory of each processing unit is defined by the user. The arrangement of stack memory fully flexible and can be dynamically adjusted by the user. For indirect memory access mechanism, the data memory is used as the data pointer to address the data byte. All the data memory could be the data pointer; it's quite flexible and useful to do the indirect memory access. Since the data width is 8-bit, all the 96 bytes data memory of PUD310 can be accessed by indirect access mechanism. #### 5.4. Oscillator and Clock There are three oscillator circuits provided by PUD310: internal high RC oscillator (IHRC), internal low RC oscillator (ILRC), and internal ultra-low RC oscillator (NILRC), and IHRC is enabled or disabled by registers clkmd.1 and clkmd.0 is used for ILRC and NILRC switch. User can choose one of these three oscillators as system clock source and use *clkmd* register to target the desired frequency as system clock to meet different applications, refer to Table 5.2. | Oscillator Module | Enable/Disable | |-------------------|---------------------| | IHRC | clkmd.1 | | Oscillator Module | Switch | | ILRC | <b>clkmd</b> .0 = 0 | | NILRC | <b>clkmd</b> .0 = 1 | Table 5.2: Three oscillation circuits #### 5.4.1. Internal High RC oscillator and Internal Low RC oscillator After boot-up, the IHRC and ILRC oscillators are enabled. The frequency of IHRC can be calibrated to eliminate process variation by *ihrcr* register; normally it is calibrated to 12MHz. Please refer to the measurement chart for IHRC frequency verse V<sub>DD</sub> and IHRC frequency verse temperature. The frequency will vary by process, supply voltage and temperature, please refer to DC specification and do not use for accurate timing application. #### 5.4.2. Chip calibration The IHRC frequency and bandgap reference voltage may be different chip by chip due to manufacturing variation, PUD310 provide the IHRC frequency calibration to eliminate this variation, and this function can be selected when compiling user's program and the command will be inserted into user's program automatically. The calibration command is shown as below: .ADJUST\_IC SYSCLK=IHRC/(p1), IHRC=(p2)MHz, VDD=(p3)V; Where, **p1**=2, 4, 8; In order to provide different system clock. p2=1.5~12; In order to calibrate the chip to different frequency, 12MHz is the usually one. p3=1.8~5.5; In order to calibrate the chip under different supply voltage. #### 5.4.3. IHRC Frequency Calibration and System Clock During compiling the user program, the options for IHRC calibration and system clock are shown as Table 5.3: | SYSCLK | CLKMD | IHRCR | Description | |----------------|------------------|------------|-----------------------------------------------| | o Set IHRC / 1 | = 22h (IHRC / 1) | Calibrated | IHRC calibrated to 12MHz, CLK=12MHz (IHRC/1) | | o Set IHRC / 2 | = 62h (IHRC / 2) | Calibrated | IHRC calibrated to 12MHz, CLK=6MHz (IHRC/2) | | o Set IHRC / 4 | = A2h (IHRC / 4) | Calibrated | IHRC calibrated to 12MHz, CLK=3MHz (IHRC/4) | | o Set IHRC / 8 | = E2h (IHRC / 8) | Calibrated | IHRC calibrated to 12MHz, CLK=1.5MHz (IHRC/8) | | ○ Set ILRC | = 02h (ILRC / 1) | Calibrated | IHRC calibrated to 12MHz, CLK=ILRC | | o Disable | No change | No Change | IHRC not calibrated, CLK not changed | Table 5.3: Options for IHRC Frequency Calibration Usually, .ADJUST\_IC will be the first command after boot up, in order to set the target operating frequency whenever starting the system. The program code for IHRC frequency calibration is executed only one time that occurs in writing the codes into OTP memory; after then, it will not be executed again. If the different option for IHRC calibration is chosen, the system status is also different after boot. The following shows the status of PUD310 for different option: (1) .ADJUST IC SYSCLK=IHRC/1, IHRC=12MHz, V<sub>DD</sub>=5V After boot up, RSTC = 0x04, CLKMD = 0x22: - ♦ IHRC frequency is calibrated to 12MHz@V<sub>DD</sub>=5V and IHRC module is enabled - ◆ System CLK = IHRC/1 = 12MHz - ♦ Watchdog timer is disabled, ILRC is selected, PA5 is in input mode (2) .ADJUST IC SYSCLK=IHRC/2, IHRC=12MHz, V<sub>DD</sub>=3.3V After boot up, RSTC = 0x04, CLKMD = 0x62: - ♦ IHRC frequency is calibrated to 12MHz@V<sub>DD</sub>=3.3V and IHRC module is enabled - ◆ System CLK = IHRC/2 = 6MHz - ♦ Watchdog timer is disabled, ILRC is selected, PA5 is in input mode #### (3) .ADJUST\_IC SYSCLK=IHRC/4, IHRC=12MHz, V<sub>DD</sub>=2.5V After boot up, RSTC = 0x04, CLKMD = 0xA2: - ♦ IHRC frequency is calibrated to 12MHz@V<sub>DD</sub>=2.5V and IHRC module is enabled - ◆ System CLK = IHRC/4 = 3MHz - ♦ Watchdog timer is disabled, ILRC is selected, PA5 is in input mode #### (4) .ADJUST\_IC SYSCLK=IHRC/8, IHRC=12MHz, V<sub>DD</sub>=2.5V After boot up, RSTC = 0x04, CLKMD = 0xE2: - ♦ IHRC frequency is calibrated to 12MHz@V<sub>DD</sub>=2.5V and IHRC module is enabled - ◆ System CLK = IHRC/8 = 1.5MHz - ♦ Watchdog timer is disabled, ILRC is selected, PA5 is in input mode #### (5) .ADJUST IC SYSCLK=ILRC, IHRC=12MHz, V<sub>DD</sub>=5V After boot up, RSTC = 0x04, CLKMD = 0x02: - ♦ IHRC frequency is calibrated to 12MHz@V<sub>DD</sub>=5V and IHRC module is enabled - ◆ System CLK = ILRC = 32KHz - ♦ Watchdog timer is disabled, ILRC is selected, PA5 is in input mode #### (6) .ADJUST\_IC DISABLE After boot up, CLKMD is not changed (Do nothing): - ◆ IHRC is not calibrated - ◆ System CLK = ILRC - ♦ Watchdog timer is enabled, ILRC is selected, PA5 is in input mode #### 5.4.4. System Clock and LVR level The clock source of system clock comes from IHRC, ILRC, and NILRC, the hardware diagram of system clock in the PUD310 is shown as Fig. 5.2. Fig. 5.2: Options of System Clock User can choose different operating system clock depends on its requirement; the selected operating system clock should be combined with supply voltage and LVR level to make system stable. The LVR level will be selected during compilation. Please refer to Section 4.1. #### 5.4.5. System Clock Switching After IHRC calibration, user may want to switch system clock to a new frequency or may switch system clock at any time to optimize the system performance and power consumption. Basically, the system clock of PUD310 can be switched among IHRC, ILRC and NILRC by setting the *clkmd* register at any time; system clock will be the new one after writing to *clkmd* register immediately. Please notice that the original clock module can NOT be turned off at the same time as writing command to *clkmd* register. The examples are shown as below and more information about clock switching, please refer to the "Help" $\rightarrow$ "Application Note" $\rightarrow$ "IC Introduction" $\rightarrow$ "Register Introduction" $\rightarrow$ CLKMD". | <u>Case 1:</u> | : Switching system clock from ILRC to IHRC/2 | | | | C/2 | |----------------|----------------------------------------------|----------|-----------------|----------|---------------------------------------------------------| | | ••• | | | // | system clock is ILRC | | | CLKMD.1 | = | 1; | // | turn on IHRC first to improve anti-interference ability | | | CLKMD | = | 0x62; | // | switch to IHRC/2 | | | | | | | | | <u>Case 2:</u> | Switching syste | m cloc | k from IHRC/ | 2 to ILF | RC | | | | | | // | system clock is IHRC/2 | | | CLKMD | = | 0x02 ; | // | switch to ILRC, IHRC CAN NOT be disabled here | | | CLKMD.1 | = | 0; | // | IHRC <u>CAN</u> be disabled at this time | | | | | | | | | Case 3: | Switching syste | m cloc | k from IHRC/ | 2 to IHF | RC/4 | | | ••• | | | // | system clock is IHRC/2, ILRC is enabled here | | | CLKMD | = | 0XA2; | // | switch to IHRC/4 | | | | | | | | | <u>Case 4:</u> | System may ha | ng if it | is to switch cl | lock an | d turn off original oscillator at the same time | | | | | | // | system clock is IHRC/2 | | | CLKMD | = | 0x00 ; | // | CAN NOT switch clock from IHRC/2 to ILRC and | | | | | | | turn off IHRC oscillator at the same time | #### **5.5 16-bit Timer (Timer16)** A 16-bit hardware timer (Timer16) is implemented in the PUD310, the clock sources of Timer16 may come from system clock (CLK), internal high RC oscillator (IHRC), internal low RC oscillator (ILRC), and PA0, a multiplex is used to select clock output for the clock source. Before sending clock to the counter16, a pre-scaling logic with divided-by-1, 4, 16, and 64 is used for wide range counting. The 16-bit counter performs up-counting operation only, the counter initial values can be stored from memory by *stt16* instruction and the counting values can be loaded to memory by *ldt16* instruction. A selector is used to select the interrupt condition of Timer16, whenever overflow occurs, the Timer16 interrupt can be triggered. The hardware diagram of Timer16 is shown as Fig. 5.3. The interrupt source of Timer16 comes from one of bit 8 to 15 of 16-bit counter, and the interrupt type can be rising edge trigger or falling edge trigger which is specified in the bit 4 of *integ* register (address 0x09). Fig. 5.3: Hardware diagram of Timer16 When using the Timer16, the syntax for Timer16 has been defined in the .INC file. There are three parameters to define the Timer16; 1<sup>st</sup> parameter is used to define the clock source of Timer16, 2<sup>nd</sup> parameter is used to define the pre-scalar and the last one is to define the interrupt source. The detail description is shown as below: ``` T16M IO_RW 0x0B $ 7~5: STOP, SYSCLK, X, X, IHRC, X, ILRC, PA0_F // 1<sup>st</sup> par. $ 4~3:/1, /4, /16, /64 // 2<sup>nd</sup> par. $ 2~0: BIT8, BIT9, BIT10, BIT11, BIT12, BIT13, BIT14, BIT15 // 3<sup>rd</sup> par. ``` User can define the parameters of T16M based on system requirement, some examples are shown below and more examples please refer to "Help $\rightarrow$ Application Note $\rightarrow$ IC Introduction $\rightarrow$ Register Introduction $\rightarrow$ T16M" in IDE utility. #### \$ T16M SYSCLK, /64, BIT15; ``` // choose (SYSCLK/64) as clock source, every 2^16 clock to set INTRQ.2=1 // if using System Clock = IHRC / 2 = 6 MHz // SYSCLK/64 = 6 MHz/64 = 93.75KHz, about every 700 mS to generate INTRQ.2=1 ``` #### \$ T16M ILRC, /1, BIT13; ``` // choose (ILRC/1) as clock source, every 2^14 clocks to generate INTRQ.2=1 // if ILRC=32768 Hz, 32768 Hz/(2^14) = 2Hz, every 0.5S to generate INTRQ.2=1 ``` #### \$ T16M PA0\_F, /1, BIT8; ``` // choose PA0 as clock source, every 2^9 to generate INTRQ.2=1 // receiving every 512 times PA0 to generate INTRQ.2=1 ``` #### **\$ T16M STOP**; // stop Timer16 counting If Timer16 is operated at free running, the frequency of interrupt can be described as below: ``` F_{INTRQ\_T16M} = F_{clock source} \div P \div 2^{n+1} ``` Where, F is the frequency of selected clock source to Timer16; P is the selection of t16m [4:3]; (1, 4, 16, 64) N is the $n^{th}$ bit selected to request interrupt service, for example: n=10 if bit 10 is selected. #### 5.6 8-bit Timer (Timer2) with PWM generation An 8-bit hardware timer (Timer2) with PWM generation is implemented in the PUD310. Please refer to Fig. 5.4 shown the hardware diagram of Timer2, the clock sources of Timer2 may come from internal high RC oscillator (IHRC), 2x internal high RC oscillator (IHRC\*2), and internal low RC oscillator (ILRC). Bit [5:4] of register tpw2c are used to select the clock of Timer2 PWM. If IHRC is selected for Timer2 clock source, the clock sent to Timer2 will keep running when using ICE in halt state. The output of Timer2 can be sent to pin PA3, depending on bit [6:5] of tpw2s register. A clock pre-scaling module is provided with divided-by- 1, 4, 16, and 64 options, controlled by bit [3:2] of tpw2c register; one scaling module with divided-by-1~32 is also provided and controlled by bit [4:0] of tpw2s register. In conjunction of pre-scaling function and scaling function, the frequency of Timer2 PWM clock (TPW2\_CLK) can be wide range and flexible. The Timer2 counter performs 8-bit up-counting operation only. The 8-bit counter will be clear to zero automatically when its values reach for upper bound register in period mode. The upper bound register is used to define the period of timer or duty of PWM. There are two operating modes for Timer2: period mode and PWM mode; period mode is used to generate periodical output waveform or interrupt event; PWM mode is used to generate PWM output waveform with optional 6-bit, 7-bit or 8-bit PWM resolution, Fig. 5.5 shows the timing diagram of Timer2 for both period mode and PWM mode. Fig. 5.4: Timer2 hardware diagram Fig. 5.5: Timing diagram of Timer2 in period mode and PWM mode (tpw2c.6=1) #### 5.6.1 Using the Timer2 to generate periodical waveform If periodical mode is selected, the duty cycle of output is always 50%; its frequency can be summarized as below: #### Frequency of Output = $Y \div [2 \times (K+1) \times S1 \times (S2+1)]$ Where, Y = tpw2c[5:4]: frequency of selected clock source K = tpw2b[7:0] : bound register in decimal S1 = tpw2c[3:2] : pre-scalar (S1=1, 4, 16, 64) S2 = tpw2s[4:0] : scalar register in decimal (S2=0 ~ 31) ``` Example 1: ``` ``` tpw2c = 0b0000 0000, Y=12MHz, S1=1 tpw2b = 0b0111_1111, K=127 tpw2s = 0b010 00000, S2=0 → frequency of output = 12MHz \div [2 \times (127+1) \times 1 \times (0+1)] = 46.875KHz Example 2: tpw2c = 0b0000_1100, Y=12MHz, S1=64 tpw2b = 0b0111 1111, K=127 tpw2s = 0b010_111111, S2 = 31 \rightarrow frequency of output = 12MHz \div (2 × (127+1) × 64 × (31+1)) =22.89Hz Example 3: tpw2c = 0b0000_0000, Y=12MHz, S1=1 tpw2b = 0b0000 1111, K=15 tpw2s = 0b010 00000, S2=0 \rightarrow frequency of output = 12MHz \div (2 × (15+1) × 1 × (0+1)) = 375KHz Example 4: tpw2c = 0b0000_0000, Y=12MHz, S1=1 ``` ``` tpw2b = 0b0000_0001, K=1 tpw2s = 0b010 00000, S2=0 → frequency of output = 12MHz \div (2 \times (1+1) \times 1 \times (0+1)) = 3MHz ``` The sample program for using the Timer2 to generate periodical waveform from PA3 is shown as below: ``` Void FPPA0 (void) { . ADJUST IC SYSCLK=IHRC/2, IHRC=12MHz, V<sub>DD</sub>=5V tpw2c = 0x0; tpw2b = 0x7f; tpw2s = 0b0_10_00001; output=PA3, scalar = 2 tpw2c = 0b1000\_00\_00; // period mode , IHRC, pre-scalar = 1 while(1) { nop; } ``` } #### 5.6.2 Using the Timer2 to generate 8-bit PWM waveform If 8-bit PWM mode is selected, it should set *tpw2c*[6]=1 and *tpw2c*[1:0]=2'b00, the frequency and duty cycle of output waveform can be summarized as below: #### Frequency of Output = $Y \div [256 \times S1 \times (S2+1)]$ Duty of Output = $$[(K+1) \div 256] \times 100\%$$ Where, Y = tpw2c[5:4]: frequency of selected clock source K = tpw2b[7:0] : bound register in decimal S1= tpw2c[3:2] : pre-scalar (S1=1, 4, 16, 64) S2 = tpw2s[4:0] : scalar register in decimal (S2=0 ~ 31) #### Example 1: tpw2c = 0b0100\_0000, Y=12MHz, S1=1 tpw2b = 0b0111\_1111, K=127 tpw2s = 0b010\_00000, S2=0 → frequency of output = 12MHz ÷ ( 256 × 1 × (0+1) ) = 46.875KHz $\rightarrow$ duty of output = [(127+1) ÷ 256] × 100% = 50% #### Example 2: tpw2c = 0b0100\_1100, Y=12MHz, S1=64 tpw2b = 0b0111 1111, K=127 tpw2s = 0b010\_11111, S2=31 → frequency of output = 12MHz ÷ ( 256 × 64 × (31+1) ) = 22.89Hz → duty of output = $[(127+1) \div 256] \times 100\% = 50\%$ #### Example 3: tpw2c = 0b0100\_0000, Y=12MHz, S1=1 tpw2b = 0b1111\_1111, K=255 tpw2s = 0b010\_00000, S2=0 → PWM output keep high $\rightarrow$ duty of output = [(255+1) ÷ 256] × 100% = 100% #### Example 4: tpw2c = 0b0100\_0000, Y=12MHz, S1=1 tpw2b = 0b0000 1001, K = 9 tpw2s = 0b010\_00000, S2=0 → frequency of output = 12MHz ÷ ( 256 × 1 × (0+1) ) = 46.875KHz $\rightarrow$ duty of output = [(9+1) ÷ 256] × 100% = 3.9% The sample program for using the Timer2 to generate PWM waveform from PA3 is shown as below: ``` void FPPA0 (void) { .ADJUST_IC SYSCLK=IHRC/2, IHRC=12MHz, V<sub>DD</sub>=5V wdreset; tpw2c = 0x0; tpw2b = 0x7f; // tpw2s = 0b0_10_00001; output=PA3, scalar = 2 tpw2c = 0b1100 00 00; // PWM mode , IHRC, pre-scalar = 1 8-bit PWM // while(1) nop; } ``` #### 5.6.3 Using the Timer2 to generate 6-bit PWM waveform If 6-bit PWM mode is selected, it should set **tpw2c**[6]=1 and **tpw2c**[1:0]=2'b10, the frequency and duty cycle of output waveform can be summarized as below: ``` Frequency of Output = Y \div [64 \times S1 \times (S2+1)] Duty of Output = [(K+1) \div 64] \times 100\% Where, tpw2c[5:4] = Y : frequency of selected clock source tpw2b[7:0] = K : bound register in decimal tpw2c[3:2] = S1 : pre-scalar (S1=1, 4, 16, 64) tpw2s[4:0] = S2 : scalar register in decimal (S2=0 ~ 31) Example 1: tpw2c = 0b0100 0010, Y=12MHz, S1=1 tpw2b = 0b0001_11111, K = 31 tpw2s = 0b010_00000, S2=0 → frequency of output = 12MHz ÷ (64 × 1 × (0+1)) = 187.5KHz \rightarrow duty = [(31+1) ÷ 64] × 100% = 50% Example 2: tpw2c = 0b0100 1110, Y=12MHz, S1=64 tpw2b = 0b0001 1111, K = 31 tpw2s = 0b010_11111, S2=31 → frequency of output = 12MHz ÷ (64 × 64 × (31+1)) = 91.55 Hz \rightarrow duty of output = [(31+1) ÷ 64] × 100% = 50% ``` #### Example 3: tpw2c = 0b0100\_0010, Y=12MHz, S1=1 tpw2b = 0b0011\_1111, K=63 tpw2s = 0b010\_00000, S2=0 → PWM output keep high $\rightarrow$ duty of output = [(63+1) ÷ 64] × 100% = 100% #### Example 4: tpw2c = 0b0100\_0010, Y=12MHz, S1=1 tpw2b = 0b0000\_0000, K=0 tpw2s = 0b010\_00000, S2=0 $\rightarrow$ frequency = 12MHz ÷ (64 × 1 × (0+1)) = 187.5KHz $\rightarrow$ duty = [(0+1) ÷ 64] × 100% = 1.5% #### 5.6.4 PWM Waveform A PWM output waveform (Fig. 5.6) has a time-base ( $T_{Period}$ = Time of Period) and a time with output high level (Duty Cycle). The frequency of the PWM output is the inverse of the period ( $f_{PWM}$ = 1/ $T_{Period}$ ). Fig. 5.6: PWM Output Waveform ### 5.7 WatchDog Timer The watchdog timer (WDT) is a counter with clock coming from ILRC. WDT can be cleared by power-on-reset or by command *wdreset* at any time. There are four different timeout periods of watchdog timer to be chosen by setting the *rstc* register, it is: - ◆ 8k ILRC clocks period if register rstc[5:4]=00 (default) - ◆ 16k ILRC clocks period if register rstc[5:4]=01 - ◆ 64k ILRC clocks period if register rstc[5:4]=10 - 256k ILRC clocks period if register rstc[5:4]=11 The frequency of ILRC may drift a lot due to the variation of manufacture, supply voltage and temperature; user should reserve guard band for save operation. Besides, the watchdog period will also be shorter than expected after Reset or Wakeup events. It is suggested to clear WDT by wdreset command after these events to ensure enough clock periods before WDT timeout. When WDT is timeout, PUD310 will be reset to restart the program execution. The relative timing diagram of watchdog timer is shown as Fig. 5.7. Fig. 5.7: Sequence of Watch Dog Time Out ### 5.8 Interrupt There are eight interrupt lines for PUD310: ◆ External interrupt PA0 ♦ Timer16 interrupt ◆ PD\_PHY interrupt ◆ TPW2 interrupt Every interrupt request line has its own corresponding interrupt control bit to enable or disable it; the hardware diagram of interrupt function is shown as Fig. 5.8. All the interrupt request flags are set by hardware and cleared by writing *intrq* register. When the request flags are set (External PA0 and Timer16 interrupt only), it can be rising edge, falling edge or both, depending on the setting of register *integs*. All the interrupt request lines are also controlled by *engint* instruction (enable global interrupt) to enable interrupt operation and *disgint* instruction (disable global interrupt) to disable it. The stack memory for interrupt is shared with data memory and its address is specified by stack register *sp*. Since the program counter is 16 bits width, the bit 0 of stack register *sp* should be kept 0. Moreover, user can use *pushaf* / *popaf* instructions to store or restore the values of *ACC* and *flag* register *to* / *from* stack memory. Since the stack memory is shared with data memory, the stack position and level are arranged by the compiler in Mini-C project. When defining the stack level in ASM project, users should arrange their locations carefully to prevent address conflicts. Fig. 5.8: Hardware diagram of interrupt controller Once the interrupt occurs, its operation will be: - ◆ The program counter will be stored automatically to the stack memory specified by register sp. - New sp will be updated to sp+2. - Global interrupt will be disabled automatically. - The next instruction will be fetched from address 0x010. During the interrupt service routine, the interrupt source can be determined by reading the *intrq* register. Note: Even if INTEN=0, INTRQ will be still triggered by the interrupt source. After finishing the interrupt service routine and issuing the *reti* instruction to return, its operation will be: - ◆ The program counter will be restored automatically from the stack memory specified by register sp. - ♦ New sp will be updated to sp-2. - Global interrupt will be enabled automatically. - ◆ The next instruction will be the original one before interrupt. User must reserve enough stack memory for interrupt, two bytes stack memory for one level interrupt and four bytes for two levels interrupt. And so on, two bytes stack memory is for *pushaf*. For interrupt operation, the following sample program shows how to handle the interrupt, noticing that it needs four bytes stack memory to handle one level interrupt and *pushaf*. ``` FPPA0 (void) void { $ INTEN PAO; // INTEN =1; interrupt request when PA0 level changed // clear INTRQ INTRQ = 0; ENGINT // global interrupt enable DISGINT // global interrupt disable } void Interrupt (void) // interrupt service routine { PUSHAF // store ALU and FLAG register // If INTEN.PA0 will be opened and closed dynamically, // user can judge whether INTEN.PA0 =1 or not. // Example: If (INTEN.PA0 && INTRQ.PA0) {...} // If INTEN.PA0 is always enable, // user can omit the INTEN.PA0 judgement to speed up interrupt service routine. If (INTRQ.PA0) // Here for PA0 interrupt service routine { INTRQ.PA0 = 0; // Delete corresponding bit (take PA0 for example) ``` ``` ... // X: INTRQ = 0; // It is not recommended to use INTRQ = 0 to clear all at the end of the // interrupt service routine. // It may accidentally clear out the interrupts that have just occurred // and are not yet processed. POPAF // restore ALU and FLAG register } ``` #### 5.9 Power-Save and Power-Down There are three operational modes defined by hardware: ON mode, Power-Save mode and Power-Down modes. ON mode is the state of normal operation with all functions ON, Power-Save mode ("stopexe") is the state to reduce operating current and CPU keeps ready to continue, Power-Down mode ("stopsys") is used to save power deeply. Therefore, Power-Save mode is used in the system which needs low operating power with wake-up occasionally and Power-Down mode is used in the system which needs power down deeply with seldom wake-up. Table 5.4 shows the differences in oscillator modules between Power-Save mode ("stopexe") and Power-Down mode ("stopsys"). | Differences in oscillator modules between STOPSYS and STOPEXE | | | | | | |---------------------------------------------------------------|-----------|-----------|--|--|--| | IHRC ILRC | | | | | | | STOPSYS | Stop | Stop | | | | | STOPEXE | No Change | No Change | | | | Table 5.4: Differences in oscillator modules between STOPSYS and STOPEXE ### 5.9.1 Power-Save mode ("stopexe") Using "stopexe" instruction to enter the Power-Save mode, only system clock is disabled, remaining all the oscillator modules active. For CPU, it stops executing; however, for Timer16, counter keep counting if its clock source is not the system clock. Wake-up from input pins can be considered as a continuation of normal execution, the detail information for Power-Save mode shows below: - IHRC oscillator modules: No change, keep active if it was enabled. - ILRC oscillator modules: must remain enabled, need to start with ILRC when be wakening up. - System clock: Disable, therefore, CPU stops execution. - OTP memory is turned off. - Timer counter: Stop counting if its clock source is system clock or the corresponding oscillator module is disabled; otherwise, it keeps counting. (The Timer contains TM16, TPW2.) - Wake-up sources: - a. IO toggle wake-up: IO toggling in digital input mode (PxC bit is 0 and PxDIER bit is 1) - b. Timer wake-up: If the clock source of Timer is not the SYSCLK, the system will be awakened when the Timer counter reaches the set value, it is awakened on both the rising and falling edges. An example shows how to use Timer16 to wake-up from "stopexe": ``` $ T16M ILRC, /1, BIT8 // Timer16 setting ... WORD count = 0; STT16 count; stopexe; ``` The initial counting value of Timer16 is zero and the system will be woken up after the Timer16 counts 256 ILRC clocks. #### 5.9.2 Power-Down mode ("stopsys") Power-Down mode is the state of deeply power-saving with turning off all the oscillator modules. The following shows the internal status of PUD310 detail when "*stopsys*" command is issued: - All the oscillator modules are turned off. - OTP memory is turned off. - The contents of SRAM and registers remain unchanged. - Wake-up sources: IO toggle in digital mode (PxDIER bit is 1) Wake-up from input pins can be considered as a continuation of normal execution. To minimize power consumption, all the I/O pins should be carefully manipulated before entering power-down mode. The reference sample program for power down is shown as below: ``` CLKMD Change clock from IHRC to ILRC 0x22; // // disable IHRC CLKMD.1 0; while (1) STOPSYS: // enter power-down if (...) break; // if wakeup happen and check OK, then return to high speed, else stay in power-down mode again // CLKMD 0x62; // Change clock from ILRC to IHRC/2 ``` #### 5.9.3 Wake-up After entering the Power-Down or Power-Save modes, the PUD310 can be resumed to normal operation by toggling IO pins. Wake-up from timer are available for Power-Save mode ONLY. Table 5.5 shows the differences in wake-up sources between STOPSYS and STOPEXE. | Differences in wake-up sources between STOPSYS and STOPEXE | | | | | |------------------------------------------------------------|-----------|-----------------|--|--| | | IO Toggle | Timer Interrupt | | | | STOPSYS | Yes | No | | | | STOPEXE | Yes | Yes | | | Table 5.5: Differences in wake-up sources between Power-Save mode and Power-Down mode When using the IO pins to wake-up the PUD310, the IO pins must bigger than 1 operation instruction and registers *pxdier* should be properly set to enable the wake-up function for every corresponding pin. The time for normal wake-up is about 1024 ILRC clocks counting from wake-up event; fast wake-up can be selected to reduce the wake-up time by *rstc* register, and the time for fast wake-up is about 16 ILRC clocks from IO toggling, refer to Table 5.6. | Suspend mode | Wake-up mode | Wake-up time (twup) from IO toggle | |-----------------|----------------|-----------------------------------------------------| | STOPEXE suspend | | 16 * T | | or | Fast wake-up | 16 * Tilro, | | STOPSYS suspend | | Where TILRC is the time period of ILRC | | STOPEXE suspend | | 4004 * T | | or | Normal wake-up | 1024 * TILRC, | | STOPSYS suspend | | Where T <sub>ILRC</sub> is the clock period of ILRC | Table 5.6: Differences in wake-up time between Fast/Normal wake-up #### 5.10 IO Pins All the pins can be independently set into two states output or input by configuring the data registers (*pa*, *pb*), control registers (*pac*, *pbc*) and pull-high resistor (*paph*, *pbph*). All these pins have Schmitt-trigger input buffer and output driver with CMOS level. When it is set to output low, the pull-high resistor is turned off automatically. If user wants to read the pin state, please notice that it should be set to input mode before reading the data port; if user reads the data port when it is set to output mode, the reading data comes from data register, NOT from IO pad. As an example, Table 5.7 shows the configuration table of bit 0 of port A. The hardware diagram of IO buffer is also shown as Fig. 5.9. | pa.0 | pac.0 | paph.0 | Description | |------|-------|--------|----------------------------------------| | Χ | 0 | 0 | Input without pull-high resistor | | Χ | 0 | 1 | Input with pull-high resistor | | 0 | 1 | Х | Output low without pull-high resistor | | 1 | 1 | 0 | Output high without pull-high resistor | | 1 | 1 | 1 | Output high with pull-high resistor | Table 5.7: PA0 Configuration Table Page 43 of 102 Fig. 5.9: Hardware diagram of IO buffer Except than PA7, PA1, PA2, PA4, PA6, PA7 can be open-drain ONLY when setting to output mode; PA1, PA2, PA4, PA6 are PD special IO. Others IO pins have the same structure; The corresponding bits in registers *padier | pbdier* should be set to low to prevent leakage current for those pins are selected to be analog function. When PUD310 is put in power-down or power-save mode, every pin can be used to wake-up system by toggling its state. Therefore, those pins needed to wake-up system must be set to input mode and set the corresponding bits of registers *padier* and *pbdier* to high. The same reason, *padier*.0 should be set high when PA0 is used as external interrupt pin, *pbdier*.0 for PB0, and *padier*.3 for PA3. #### 5.11 Reset and LVR ### 5.11.1 Reset There are many causes to reset the PUD310, once reset is asserted, most of all the registers in PUD310 will be set to default values, system should be restarted once abnormal cases happen, or by jumping program counter to address 0x00. After power-up and LVR reset, the SRAM data will be kept when $V_{DD}>V_{DR}$ (SRAM data retention voltage). However, if SRAM is cleared after power-on again, the data cannot be kept. And, the data memory is in uncertain state when $V_{DD}<V_{DR}$ . The content will be kept when reset comes from PRSTB pin or WDT timeout. #### 5.11.2 LVR reset By code option, there are many different levels of LVR for reset. Usually, user selects LVR reset level to be in conjunction with operating frequency and supply voltage. #### 5.12 PD PHY Controller #### 5.12.1 Features PD PHY controller is a USB PD capable sink-end device responsible for sending and receiving messages on the CC wire. The main function executes the PD physical layer signal communications and supplies a simple access interface to system software, which let user can do the most effective management for the protocol layer. In addition, this function block is also responsible for all signal control of Analog Front End (AFE), please see section 5.13 for details. #### ■ Hardware Features: - Standard MCU system bus interface for register access. - One PD PHY system interrupt comprises TX interrupt, RX interrupt and RX FIFO Half Full interrupt - One shared 4 bytes TX/RX FIFO. - Supports Internal loopback testing (digital TX to RX data path) and external loopback testing (digital and analog TX to RX data path). - Supports inner signal monitor capability through GPIOs for software protocol layer development. #### ■ USB PD Physical Layer Features: - Transmit and receive only two kinds of PD signals, SOP packet and Hard Reset signaling. SOP', SOP", and other signaling will be auto omitted by the controller, which reduce the unnecessary data flows between the physical layer and protocol layer. - Supports the BIST signaling for TX eye diagram measurement. - Receiving data capability adjustment for particular cable and connector application. ### 5.12.2 Block Diagram Fig. 5.10 shown below illustrates the block diagram of the PD PHY controller and Analog Front End (AFE) macro. This controller comprises a transmitting and receiving data flow controller (TX/RX CTRL), a data encoder and transmitter (Transmitter), a data decoder and receiver (Receiver), a shared TX/RX CRC generator (CRC32), a shared TX/RX data storage unit (TX/RX FIFO) and a register file (Regfile). Transmitting data path (TX data path) is composed of Transmitter, CRC32 and TX/RX FIFO, while receiving data path (RX data path) is composed of Receiver, CRC32, and TX/RX FIFO. It is noted that CRC32 and TX/RX FIFO are shared by both TX and RX data paths, so data transfer and data receiving are not allowed to operate at the same time, excluding internal/external loopback testing mode. All related registers of PD PHY controller and AFE macro are allocated at the Regfile. The Regfile supplies one standard MCU system bus interface as register access. The AFE registers in the Regfile are used to manage all operation of the AFE macro. The TX/RX CTRL controls the TX/RX data flow direction, handles all protocol errors, and communicates with application software responsible for managing all transactions from the protocol layer. The TX/RX FIFO holds data to be transferred in the TX operation mode, and stores received data in the RX operation mode. The TX/RX FIFO is a 4-byte storage unit. In the RX operation mode, one half-full interrupt will be asserted when ≥2 bytes have been stored in the FIFO, and will be automatically de-asserted when less than 2 bytes stay in the FIFO by reading received data. It is noted that this half-full interrupt will not function in the TX operation mode. Based on the USB PD specification, the CRC32 is used for generating the checksum at the both TX and RX operation mode. Fig. 5.10: Block Diagram of PD PHY Controller and AFE For each SOP packet transmission, at first Transmitter generates a 64-bit Preamble automatically and then reads data from the TX/RX FIFO and CRC32 and executes the 4b5b encoding with them. The Transmitter also generates SOP and EOP symbols which will be pre-appended or appended to these encoded data. Finally, do the BMC encoding before sending this SOP packet. Besides, the Transmitter also can generate a Hard Reset signaling or BIST signaling described in the USB PD specification. One TX interrupt will be asserted when a SOP transmission has been executed successfully, including Hard Reset signaling and BIST signaling. TX interrupt must be cleared by user, please see section 5.12.3.4 for details. When any signal occurs on the CC wire (from bus idle to bus active), the Receiver will start to try the BMC decoding. User also can acquire the bus idle or active information through reading the specified register. If one legal SOP packet is detected, all data payload and 32-bit CRC after 4b5b decoding will be transferred to the CRC32 and stored in the TX/RX FIFO. The first RX half-full interrupt will be asserted when two bytes have been stored in the FIFO. Whenever the RX half-full interrupt occurs, user must read these received data as soon as possible; otherwise, one FIFO overrun will cause this correct packet to be regarded as one failed transfer. Once the first RX half-full interrupt has been asserted, another RX interrupt will be also generated when the CC wire returns to the bus idle again. Whether the received data is correct or not, user must finish this packet transaction. In addition, if a Hard Reset signaling is received successfully, one RX interrupt can be also asserted. It is noted that the SOP', SOP" packets and other signaling, including the meaningless signal or noise, will be auto omitted by the Receiver, and no message and interrupt will be generated to application software. ### 5.12.3 Function Description This section illustrates all PD PHY controller functions and the TX/RX operation procedures. Some useful information also be mentioned. #### 5.12.3.1 TX/RX Hardware State Diagram Fig. 5.11: TX and RX Hardware State Diagram | Operation Mode | Signal Type | Comment | |-------------------|---------------------|----------------------------| | TX Operation Mode | SOP packet | | | TX Operation Mode | Hard Reset singling | | | TX Operation Mode | BIST singling | Only used in the test mode | | RX Operation Mode | SOP packet | | | RX Operation Mode | Hard Reset singling | | Table 5.8: Accepted Packet and Signaling Types Fig. 5.11 illustrates the hardware behaviors of the PD PHY controller when sending or receiving data. Table 5.8 describes which signal types can be accepted or operated under the control of the controller. Before starting any operation, user must set PHYCTRL\_EN of pd\_txrx register to 1 to enable the controller. Setting PHYCTRL\_EN to 0 will force the controller to the default state from any other one, including the PD PHY interrupt and all status flags of pd\_stat register. It also can be used as a soft reset of the controller. Set the TX\_START of pd\_txrx register to 1 to start one new SOP packet transfer, including one Hard Reset and BIST singling transmission. Once this transmission is complete, the Int\_TX interrupt will be automatically asserted. If this transfer is successful, both TX\_FINISH and FIFO\_EMPTY of pd\_stat will be set to 1. It is a rare possibility that when TX\_START is enabled, one packet on the CC wire is detecting by the controller at the same time. Basically, the priority of RX operation is higher than TX operation in the hardware algorithm, so this transmission will be auto omitted and TX\_FINISH will not be active forever, that is, one unexpected TX/RX collision may occur. This exception could come from a PD protocol error; user must provide one proper algorithm to solve this issue (please see section 5.12.3.7 for details). When any signal occurs on the CC wire, the controller will try to detect and analyze this received data. The PD PHY controller only accepts the SOP packet and Hard Reset signaling, and other type of received data will be regarded as a meaningless signal, which will be ignored automatically by the controller. If one Hard Reset singling is detected successfully, the Int\_RX interrupt will be asserted to tell system program, and the RX\_FINISH, RX\_SUCCESS and STATUS\_HDRST of pd\_stat register will be set to 1. If one SOP packet is detected, data payload and 32-bit CRC data will be stored in the FIFO. When two bytes have been received and stored in the FIFO, the first Int\_HalfFull interrupt will be asserted until less than two bytes stay in the FIFO by reading the pd\_fifo register. Each received data will continue to be stored in the FIFO hereafter. Each time two bytes, including 3 and 4, stay in the FIFO, the Int\_HalfFull interrupt will be asserted again. Until the EOP symbol of packet or incorrect data is detected, this reception process will be stopped, and meantime one Int\_RX interrupt will be asserted and RX\_FINISH is also set to 1. RX\_SUCCESS can be used to decide whether one correct packet has been received successfully or not. Finally, user must set the RX\_CLR of pd\_txrx register to make the controller return back to the initial state again. Now, another TX or RX operation can continue to be executed. If user want to monitor the state transition and inner signals of the controller in the Fig. 5.11, they also can be probed on the GPIOs (please see section 5.12.3.10 for details). #### 5.12.3.2 TX Flow Control Fig. 5.12 describes the basic flow chart of one standard SOP packet transfer, and Fig. 5.13 and Fig. 5.14 describe how to transmit one Hard Reset or BIST signaling individually. (NOTE: It is not necessary to follow these flow charts if user want to develop own policy for the particular application.) Read the STATUS\_IDLE of pd\_stat register to check whether the CC wire is bus idle or not, which avoids the collision occurrence of data transmission and reception at the same time. Enable the TX\_START of pd\_txrx register to start one new transfer, and meantime the controller also starts to generate automatically a 64-bit Preamble on the CC wire. The time of entire Preamble transmission is enough to prepare the transmitted data for software. Write the data payload of a SOP packet to the pd\_fifo register, and check the FIFO\_FULL of pd\_stat register to decide the next data writing. The controller always monitors the FIFO status through the FIFO\_EMPTY of pd\_stat register during entire data transfer. Once the FIFO is found empty, the controller regards it as no data wanted to be transmitted again. When this transfer is complete, the Int\_TX interrupt will be asserted. Check the TX\_FINISH of pd\_stat register to assure that data transfer has be executed successfully and no exception occurs. Finally, set TX\_CLR of pd\_txrx register to clear all hardware status and PD PHY interrupt. The flow chat of a Hard Reset signaling transmission is identical to the one used in the SOP packet, except that no data payload is needed to be transmitted, and SEND\_HDRST of pd\_txrx register must be set first before the TX\_START setting. The BIST signaling can be only used in the test mode, and the SEND\_BIST of pd\_txrx register is used for generating these test signals. Fig. 5.12: TX Flow Chart (SOP Packet) Fig. 5.13: TX Flow Chart (Hard Reset Signaling) Fig. 5.14: TX Flow Chart (BIST Signaling) ### 5.12.3.3 RX Flow Control Fig. 5.15 shown below illustrates the flow chat of a SOP packet or Hard Reset signaling reception. (NOTE: It is not necessary to follow this flow chart if user want to develop own policy for the particular application.) If the first PD PHY interrupt occurs, user must check the RX\_FINISH of pd\_stat register to decide whether it is an Int\_RX or Int\_HalfFull interrupt. If RX\_FINISH is set to 1, it must be Int\_RX, otherwise an Int\_HalfFull interrupt occurs. If this is an Int\_RX interrupt type, then read the RX\_SUCCESS of pd\_stat register to check whether it is set to 1 or not. If the RX\_SUCCESS is set to 1, the received data must be one Hard Reset singling, otherwise it is regarded as a broken packet or signaling and no action need be taken. Also, check the STATUS\_HDRST of pd\_stat register to confirm that the received data is a Hard-Reset singling. If the first interrupt is an Int\_HalfFull interrupt, it must be a SOP packet. Read received data from the pd\_fifo register until the FIFO\_EMPTY of pd\_stat is back to the default value. Wait the next interrupt occurs, check the RX\_FINISH flag and read received data from the FIFO again. Once the final EOP symbol or the broken data has been detected by the controller, the Int\_RX interrupt will be asserted and RX\_FINISH is set to 1. Check RX\_SUCCESS to decide whether the correct packet has been received or not. Finally, read the residual data in the FIFO and set RX\_CLR of pd\_txrx register to 1 to clear the PD PHY interrupt and all status flags. Table 5.9 describes the relationship between the status flags and received signal types. According to this table content, it is easy to decide which packet or signaling is receiving by the controller. Table 5.10 describes how to clear the PD PHY interrupt sources, and Table 5.11 shows the clear method of all status flags in the pd\_stat register. Fig. 5.15: RX Flow Chart | | RX_FINISH | RX_SUCCESS | STATUS_HDRST | |---------------------|-----------|------------|--------------| | SOP Packet | 1 | 1 | 0 | | Hard Reset Singling | 1 | 1 | 1 | | Broken Packet | 1 | 0 | 0 | Table 5.9: Relationship between Status Flag and Signal Type | | PHYCTRL_EN = 0 | TX_CLR = 1 | RX_CLR = 1 | Read FIFO | |--------------|----------------|------------|------------|-----------| | Int_TX | Clear | Clear | Clear | N.A. | | Int_RX | Clear | Clear | Clear | N.A. | | Int_HalfFull | Clear | N.A. | Clear | Clear | Table 5.10: PD PHY Interrupt Clear Method | | PHYCTRL_EN = 0 | TX_CLR = 1 | RX_CLR = 1 | Read FIFO | |--------------|----------------|------------|------------|-----------| | TX_FINISH | Clear | Clear | N.A. | N.A. | | RX_FINISH | Clear | N.A. | Clear | N.A. | | RX_SUCCESS | Clear | N.A. | Clear | N.A. | | FIFO_EMPTY | Clear | N.A. | Clear | Clear | | FIFO_FULL | Clear | N.A. | Clear | Clear | | STATUS_HDRST | Clear | N.A. | Clear | N.A. | | STATUS_IDLE | Clear | N.A. | N.A. | N.A. | Table 5.11: PD PHY Status Flag Clear Method ### 5.12.3.4 PD PHY Interrupt Type PD PHY interrupt is composed of three independent interrupt sources and is a level-trigger mode, shown as Fig. 5.16. The system interrupt enable is defined in the bit1 of inten register. The system interrupt status is defined in the bit1 of intrq register. The interrupt reset method is described as Table 5.10 shown above. It is noted that there is no corresponding flag for Int\_TX, Int\_RX and Int\_HalfFull for the sake of reducing the complexity of operation for software. ### PD PHY Interrupt = Int\_TX | Int\_RX | Int\_HalfFull: - Int\_TX: will be active when TX has transmitted one packet or signaling. - Int\_RX: will be active when RX has received one legal packet or signaling, or the broken packet data. - Int HalfFull: will be active when FIFO has received 2/3/4 bytes at the RX operation mode. Fig. 5.16: PD PHY Interrupt Type #### 5.12.3.5 TX/RX FIFO Access Here are some TX/RX FIFO features: - 1. One fixed 4 bytes FIFO. - **2.** FIFO is shared by both TX and RX data paths, so transmitting and receiving data simultaneously are not allowed, excluding the internal and external loopback testing mode. - **3.** In the TX operation mode, FIFO is only allowed to be written by user; in the RX operation mode, FIFO is only allowed to be read by user. - **4.** After writing one byte into the FIFO, must set FIFO\_WR of pd\_txrx register to 1 first, then set 0 (Or, set 0 first, then set 1. It is a rising-edge trigger mode.). Do this operation to update the write index of the FIFO - **5.** After reading one byte from the FIFO, must set FIFO\_RD of pd\_txrx register to 1 first, then set 0 (Or, set 0 first, then set 1. It is a rising-edge trigger mode.). Do this operation to update the read index of the FIFO. - 6. The Int Half Full interrupt is only used and asserted at the RX operation mode. - 7. The last four bytes of received data must be the 32-bit CRC data if it is a correct SOP packet. #### 5.12.3.6 CRC32 Features The following CRC information comes from the USB PD specification. Please see the related documents for details. CRC-32 is used to protect the data integrity of the data payload. CRC-32 is defined as follows: - The CRC-32 polynomial shall be = 04C1 1DB7h - The CRC-32 initial value shall be = FFFF FFFFh - CRC-32 shall be calculated for all bytes of the payload not inclusive of any packet framing symbols (i.e. excludes the Preamble, SOP\*, EOP). - CRC-32 calculation shall begin at byte 0, bit 0 and continue to bit 7 of each of the bytes of the packet. - The remainder of CRC-32 shall be complemented - The residual of CRC-32 shall be C704 DD7Bh Note: This inversion of the CRC-32 remainder adds an offset of FFFF FFFFh that will create a constant CRC-32 residual of C704 DD7Bh at the receiver side. #### 5.12.3.7 TX and RX Collision Process Section 5.12.3.1 refers to the TX/RX collision condition. In the TX operation mode, set TX\_START to start one new transmission; however, this transfer is omitted by the controller and the hardware state is force to switch into the RX operation mode. When this condition occurs, host (power source-end) and device (PD PHY controller) might lose the communication synchronization between both, and sometimes the root cause of this PD protocol error is hard to be found. The USB PD specification presents many solutions to restore to the normal communication between the power source-end and sink-end, but this needs the aids of protocol layer, that is, user must support one robust software algorithm to deal with this exception. In fact, if one unexpected error occurs, do nothing and just wait one Hard Reset signaling from the host. This can make the device restore to its initial state and restart one new transaction between the host and the device. ### 5.12.3.8 Received Signal Quality Adjustment The data receiving capability of the PD PHY controller is compliant to the USB PD standard specification. If user wants to adjust the quality of receiving data for the particular application. The controller supports the TH\_DEB, TH\_HIGH, and TH\_LOW of pd\_decoder register to meet these requirements. The TH\_DEB can deglitch the unknown signal toggles from some interferences such as spike noise. The BMC decoding principle used at the receiver is that detecting the duration of high/low voltage to decide the "Long One/Zero" or "Short One/Zero". This "Long" or "Short" decision is judged by the threshold values of both TH\_HIGH and TH\_LOW. It is noted that the improper setting of these values will cause the occurrence of the BMC decoding error. The default value for the TH\_DEB, TH\_HIGH, and TH\_LOW is typically good enough and do not need further adjustment. #### 5.12.3.9 Internal and External Loopback Mode The PD PHY controller provides two loopback modes for diagnostic testing without connecting an external device and cable. The internal loopback mode is a testing data path from digital TX to digital RX. The external loopback mode is a more complex data path which from digital TX, through analog TX and RX paths, back to digital RX finally. The TEST\_SEL, LOOP\_SEL, RX\_ACK and RX\_REQ of pd\_ctrl register are used for testing selection and operation. The programming sequences shown in the section 5.12.4.6 has the complete test procedures and test environment setting, and this example also include the detailed data which be used as the comparison of test result. #### 5.12.3.10 Inner Hardware Signal Probe Fig. 5.11 shown in the section 5.12.3.1 illustrates the state transition of hardware behaviors of the controller and the variation of the corresponding flags. This information is helpful to find the root cause of data communication errors, or is used to develop the protocol layer algorithm. These real-time signals can be probed on the GPIOs. Both PROBE\_SEL of pd\_ctrl register and bit 6:4 of opr1 register are used to select these signals to be monitored. Table 5.12 shows the relationship between the probe signals, the register setting values, and the corresponding output GPIO pins. Table 5.13 explains the definition and function of these probe signals. The signals spelled with a capital letter represent the status register name and these signals description are defined in the pd\_stat and cc\_misc register. The state name and numbering of st phy[2:0] signal is defined in the Table 5.14 shown below. | Bit 6:4 of opr1 = 001 | PB0 | PA5 | PA3 | PA0 | |--------------------------|-------------|-------------------------|-------------|-------------| | PROBE_SEL = 00 int_pd_ph | | st_phy[2] | st_phy[1] | st_phy[0] | | PROBE_SEL = 01 | fifo_ov | STATUS_HDRST RX_SUCCESS | | RX_FINISH | | PROBE_SEL = 10 FIFO_FULL | | FIFO_EMPTY | TX_FINISH | STATUS_IDLE | | PROBE_SEL = 11 | crc_cmp_out | sym_eop | pktdet_fail | BMC_BIT | Table 5.12: Probe Signal of PD PHY Controller | Probe Signal | Description | |--------------|--------------------------------------------------------------------------------| | st_phy[2:0] | State machine name in the Fig. 5.11: TX and RX Hardware State Diagram | | int_pd_phy | PD PHY controller interrupt | | fifo_ov | FIFO overrun | | crc_cmp_out | 32-bit CRC check output; 1: received data without errors, 0: CRC compare error | | sym_eop | Find a EOP symbol | | pktdet_fail | The received data cannot be decoded correctly. | Table 5.13: Probe Signal Definition | st_phy[2:0] | 0 | 1 | 2 | 3 | 4 | 5 | |-------------|----------|-----------|-------|-------|---------|--------| | State Name | TXRX_INI | TXRX_WAIT | TX_OP | RX_OP | RX_DATA | RX_FIN | Table 5.14: State Name and Numbering of st\_phy[2:0] #### 5.12.4 Programming Sequence This section scribes how to execute the proper register setting to control the PD PHY controller to transmit or receive data. These examples can be used as the basic programming sequences; however, according to the particular applications, user also can develop own program code to do the more efficient operation of the controller. ### 5.12.4.1 Transmit one SOP Packet The following programming sequence transmits one SOP packet with interrupt: - Step 1 Set PHYCTRL\_EN of pd\_txrx register to enable the PD PHY controller. - Step 2 Wait for CC wire idle by looping until STATUS\_IDLE of pd\_stat register becomes 1. - Step 3 Set TX\_START of pd\_txrx register to start a new transfer. - Step 4 Wait for FIFO not full by looping until FIFO\_FULL of pd\_stat register becomes 0. - Step 5 Write one byte of data to the *pd\_fifo* register. - Step 6 Set "1" first, then set "0" to FIFO WR of pd txrx register to update write index of FIFO. - **Step 7** If there are more data to send, go to Step 4. - Step 8 Wait for an occurrence of PD PHY interrupt. - Step 9 Check TX\_FINISH of pd\_stat register: - 1. TX FINISH = 1: This transmission is successful. - 2. TX\_FINISH = 0: This transmission is auto omitted. - Step 10 Set TX CLR of pd txrx register to clear PD PHY interrupt and all hardware status. ### 5.12.4.2 Transmit one Hard Reset Signaling The following programming sequence transmits one Hard Reset signaling with interrupt: - Step 1 Set PHYCTRL\_EN of pd\_txrx register to enable the PD PHY controller. - Step 2 Wait for CC wire idle by looping until STATUS IDLE of pd stat register becomes 1. - Step 3 Set SEND\_HDRST of pd\_txrx register to enable Hard Reset transmission. - **Step 4** Set *TX\_START* of *pd\_txrx* register to start a new transmission. - Step 5 Wait for an occurrence of PD PHY interrupt. - Step 6 Check TX\_FINISH of pd\_stat register: - 1. TX\_FINISH = 1: This transmission is successful. - 2. TX FINISH = 0: This transmission is auto omitted. - Step 7 Set TX\_CLR of pd\_txrx register to clear PD PHY interrupt and all hardware status. - Step 8 Clear SEND\_HDRST of pd\_txrx register to disable Hard Reset transmission. #### 5.12.4.3 Receive one SOP Packet The following programming sequence receives one SOP packet with interrupt: - Step 1 Set PHYCTRL\_EN of pd\_txrx register to enable the PD PHY controller. - Step 2 Wait for an occurrence of PD PHY interrupt. - Step 3 Read one byte of data from the pd\_fifo register. - Step 4 Set "1" first, then set "0" to FIFO\_RD of pd\_txrx register to update read index of FIFO. - Step 5 Go to Step 3 to read more received data if *FIFO\_EMPTY* of *pd\_stat* register is not "1". (Note: The last four bytes are 32-bit CRC data) - Step 6 Go to Step 2 to wait for the next interrupt if RX\_FINISH of pd\_stat register is not "1". - Step 7 Check RX\_SUCCESS of pd\_stat register: - 1. RX SUCCESS = 1: Receive a legal packet. - 2. RX SUCCESS = 0: Receive a broken packet. - Step 8 Set RX\_CLR of pd\_txrx register to clear PD PHY interrupt and all hardware status. #### 5.12.4.4 Receive one Hard Reset Signaling The following programming sequence receives one Hard Reset with interrupt: - Step 1 Set PHYCTRL\_EN of pd\_txrx register to enable the PD PHY controller. - Step 2 Wait for an occurrence of PD PHY interrupt. - Step 3 Check STATUS\_HDRST of pd\_stat register: - 1. **STATUS\_HDRST** = 1: Receive one Hard Reset signaling. - 2. **STATUS\_HDRST** = 0: Receive other signals. - Step 4 Set RX\_CLR of pd\_txrx register to clear PD PHY interrupt and all hardware status. ### 5.12.4.5 Transmit the BIST Signaling The following programming sequence transmits the BIST signaling with interrupt: - Step 1 Set PHYCTRL\_EN of pd\_txrx register to enable the PD PHY controller. - Step 2 Set SEND\_BIST of pd\_txrx register to enable BIST test signal transmission. - Step 3 Set TX\_START of pd\_txrx register to start a new transmission. - Step 4 Design under test. - **Step 5** Clear **SEND\_BIST** of **pd\_txrx** register to disable BIST test signal transmission. - Step 6 Wait for an occurrence of PD PHY interrupt. - Step 7 Set TX CLR of pd txrx register to clear PD PHY interrupt and all hardware status. ### 5.12.4.6 Internal and External Loopback Testing The following programming sequence describes the TX/RX internal/external loopback test with interrupt: (Note: Need additional test circuits for the external loopback testing, shown as Fig. 5.17.) - Step 1 Set PHYCTRL\_EN of pd\_txrx register to enable the PD PHY controller. - Step 2 Set TEST\_SEL of pd\_ctrl register to enable the loopback data path. - Step 3 Set LOOP\_SEL of pd\_ctrl register to select the loopback type: - 1. **LOOP SEL** = 1: TX/RX Internal Loopback (digital data path only) - 2. **LOOP\_SEL** = 0: TX/RX External Loopback (digital and analog data path) - Step 4 Set TX\_START of pd\_txrx register to start a new transmission. - Step 5 Write one byte of data to the *pd\_fifo* register. - Step 6 Set "1" first, then set "0" to FIFO\_WR of pd\_txrx register to update write index of FIFO. - Step 7 If there are more data to send, go to Step 5. - (Note: At most four bytes of transmitted data can be allowable to write into FIFO.) - Step 8 Wait for the received data by looping until RX\_REQ of pd\_ctrl register becomes 1. - **Step 9** Read one 5-bit data from the *pd\_fifo* register. - (Note: Received data is one 4b5b encoding data payload or the USB PD symbols.) - Step 10 Set *RX\_ACK* of *pd\_ctrl* register to 1. - Step 11 Wait for RX REQ of pd ctrl register becomes 0. - Step 12 Set RX\_ACK of pd\_ctrl register to 0. - Step 13 Go to Step 8 to read more data until all data has been received successfully. - (Note: 4 SOP + 8 DATA + 8 CRC + 1 EOP data should be received if 4 bytes are transmitted.) - Step 14 Wait for an occurrence of PD PHY interrupt. - Step 15 Check *TX\_FINISH* of *pd\_stat* register: - 1. **TX\_FINISH** = 1: This transmission is successful. - 2. **TX\_FINISH** = 0: This transmission is auto omitted. - Step 16 Set TX CLR of pd txrx register to clear PD PHY interrupt and all hardware status. - Step 17 Clear TEST\_SEL of pd\_ctrl register to disable the loopback data path. Example: Transmit one 4-bytes data payload SOP, and the 21 5-bit data return: TX Data Bytes: 0x02, 0x27, 0x4C, 0x71 RX 5-bit Data: 0x18, 0x18, 0x18, 0x11 (4 SOP) 0x14, 0x1e, 0x0f, 0x14, 0x1a, 0x0a, 0x09, 0x0f (8 Data) 0x09, 0x0b, 0x0e, 0x1e, 0x09, 0x12, 0x1b, 0x1a (8 CRC) 0x0d (1 EOP) Fig. 5.17: Additional Requirements for External Loopback Testing #### 5.12.4.7 CC Wire Manual Control The following programming sequence describes how to control the CC wire directly: Write logic zero/one on the CC wire: Step 1 Set CC SEL of pd ctrl register to obtain the control of the CC wire. Step 2 Set BMCTX\_EN of cc\_misc register to turn on the TX transmission. Step 3 Set the desired transmitted data in the BMCTX\_DOUT of cc\_misc register. Read logic zero/one on the CC wire: Step 1 Set CC\_SEL of pd\_ctrl register to obtain the control of the CC wire. Step 2 Set BMCRX\_EN of cc\_misc register to turn on the RX reception. Step 3 Read BMC\_BIT of cc\_misc register to acquire the received data. ### 5.13 Analog Front End (DP/DM/CC1/CC2) Analog Front End (AFE) is an analog macro for the application of general fast charging specifications. AFE comprises a DP macro, a DM macro, a CC macro, a control interface connecting to a PD PHY controller, and a USB communication interface with the DP, DM, CC1 and CC2 pins. The DP and DM macros are two independent circuits with the identical function for the DP and DM pins, while CC macro is a common hardware shared by the CC1 and CC2 pins. Fig. 5.18 illustrates the block diagram of the AFE macro. Fig. 5.18: Analog Front End (AFE) Block Diagram #### 5.13.1 Features - DP and DM Macros Features: - Support four different drive voltage levels: 5V, 3.3V, 0.6V and 0V - Support one selective voltage comparators: 3V, 2.4V, 1.2V and 0.35V - DP and DM pins have 13V high voltage tolerance capability. - DP and DM pins can be configured as OTP download cable pins in the test mode, which function is identical to a 5V GPIO. - DP and DM pins also can be operated through the GPIO control mode. ### ■ CC Macro Features: - Supports a transmitter and receiver used as data transfer of the USB PD communication. Transmitter supplies a precise 1.125V drive voltage on the CC wire, which can be trimmed in mass production. - Supports a 0.66V comparator for USB Type-C 5V/1.5A detection. - Supports a 1.23V comparator for USB Type-C 5V/3A detection. - Supports two independent 0.2V comparators used as the CC1/CC2 attached detection. - Supports two independent CC1/CC2 5.1k R<sub>d</sub> resistors. - Both CC1 and CC2 pins have 21V high voltage tolerance capability. ### 5.13.2 Block Diagram Fig. 5.19 describes the hardware architecture of the DP and DM macros. In reality, these two macros have the same function, except that one is connected to the DP pin and another is to the DM pin. Fig. 5.20 illustrates the architecture of the CC macro. It is noted that some circuits are shared by the CC1 and CC2 data paths, and others are designed individually for the CC1 and CC2 pin. Fig. 5.19: DP and DM Macro Hardware Diagram Fig. 5.20: CC Macro Hardware Diagram ### 5.13.3 Function Description ### 5.13.3.1 DP and DM Output Control According to the various charging protocols, the requirement of the DP/DM output voltage level would be not the same. The AFE DP/DM macro supplies a selective drive voltage to meet one particular application. Table 5.15 and 5.16 describe all legal setting value of dp\_out and dm\_out registers and the corresponding drive voltage. Note 1: 3.3V and 0V output voltage have two kinds of setting configuration, but user can select any one of them as the setting value. Note 2: DP\_ISINK\_EN and DM\_ISINK\_EN of dp\_out and dm\_out register are used to control a pulldown resistor which supplies an initial value after power on reset. In the normal operation mode, it is suggested that user should turn off this function after finishing the system startup. | Bit [1:0] of dp_dm_io_ctrl | 00 | 00 | 00 | 00 | 00 | 00 | 00 | |----------------------------|----|----|----|------|------|------|------| | DP_ISINK_EN | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | DP_BUFVREF_SEL | X | Х | X | X | 0 | 1 | Х | | DP_BUF_EN | 0 | 0 | 0 | 0 | 1 | 1 | 0 | | DP_TX_EN | 0 | 0 | 1 | 1 | 0 | 0 | 0 | | DP_OUT_EN | 1 | 1 | 0 | 0 | 0 | 0 | 0 | | DP_OUT | 0 | 1 | 0 | 1 | Х | Х | Х | | DP Drive Voltage | 0V | 5V | 0V | 3.3V | 0.6V | 3.3V | Hi-Z | Note 1: Bit [1:0] of dp\_dm\_io\_ctrl register must be set first before setting other register bits. Note 2: Suggest that DP\_ISINK\_EN should be disabled in the normal DP operation. Table 5.15: DP Legal Setting Value | Bit [3:2] of dp_dm_io_ctrl | 00 | 00 | 00 | 00 | 00 | 00 | 00 | |----------------------------|----|----|----|------|------|------|------| | DM_ISINK_EN | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | DM_BUFVREF_SEL | Х | X | Х | Х | 0 | 1 | Х | | DM_BUF_EN | 0 | 0 | 0 | 0 | 1 | 1 | 0 | | DM_TX_EN | 0 | 0 | 1 | 1 | 0 | 0 | 0 | | DM_OUT_EN | 1 | 1 | 0 | 0 | 0 | 0 | 0 | | DM_OUT | 0 | 1 | 0 | 1 | Х | X | Х | | DM Drive Voltage | 0V | 5V | 0V | 3.3V | 0.6V | 3.3V | Hi-Z | Note 1: Bit [3:2] of dp\_dm\_io\_ctrl register must be set first before setting other register bits. Note 2: Suggest that DM\_ISINK\_EN should be disabled in the normal DM operation. Table 5.16: DM Legal Setting Value #### 5.13.3.2 DP and DM Input Control The DP and DM macros support a selective comparator which supplies 4-level reference voltage. Table 5.17 shows the relationship between the setting of DP\_CMPVREF\_SEL and DM\_CMPVREF\_SEL of dp\_in and dm\_in registers and the comparator reference voltage. The compare output of two voltage comparators will be represented individually in the DP\_DIN and DM\_DIN of dp\_in and dm\_in registers. The DP\_CMP\_EN and DM\_CMP\_EN of dp\_in and dm\_in registers are used to enable these two comparators individually. | DP_CMPVREF_SEL DM_CMPVREF_SEL | 00 | 01 | 10 | 11 | |-------------------------------|-------|------|------|----| | Compare Voltage | 0.35V | 1.2V | 2.4V | 3V | Table 5.17: Selective Reference Voltage Comparator #### 5.13.3.3 DP and DM GPIO Control Mode The usage shown in the table 5.15 and 5.16 may be not suited to the operation of the DP and DM pins. Usually, not all drive voltage levels are necessary for a particular charging protocol in practice. In addition, it is not intuitive and convenient to control these related register setting. AFE macro also supports a GPIO control mode to simplify the DP and DM operation. The DP pin will be switched to the GPIO PA4, and the DM pin will be switched to the GPIO PA6. Most fields of dp\_out, dp\_in, dm\_out and dm\_in registers can be remapped to the ones of pa, pac and padier registers. Table 5.18 explains the transformation between the register fields of DP and PA4, and table 5.19 explains the transformation between the register fields of DM and PA6. It is noted that there are three different transformation types defined in the dp\_dm\_io\_ctrl register. Table 5.20 and Table 5.21 describe the relationship between the DP/DM status and the corresponding register setting. | Bit [1:0] of dp_dm_io_ctrl | DP | PA4 | |----------------------------|----------------|-----------| | | DP_ISINK_EN | N.A. | | | DP_BUFVREF_SEL | pa[4] | | | DP_BUF_EN | pac[4] | | | DP_TX_EN | 0 | | 01 | DP_OUT_EN | 0 | | | DP_OUT | 0 | | | DP_CMPVREF_SEL | N.A. | | | DP_CMP_EN | padier[4] | | | DP_DIN | pa[4] | | Bit [1:0] of dp_dm_io_ctrl | DP | PA4 | |----------------------------|----------------|-----------| | | DP_ISINK_EN | N.A. | | | DP_BUFVREF_SEL | 0 | | | DP_BUF_EN | 0 | | | DP_TX_EN | pac[4] | | 10 | DP_OUT_EN | 0 | | | DP_OUT | pa[4] | | | DP_CMPVREF_SEL | N.A. | | | DP_CMP_EN | padier[4] | | | DP_DIN | pa[4] | | Bit [1:0] of dp_dm_io_ctrl | DP | PA4 | |----------------------------|----------------|-----------| | | DP_ISINK_EN | N.A. | | | DP_BUFVREF_SEL | 0 | | | DP_BUF_EN | 0 | | | DP_TX_EN | 0 | | 11 | DP_OUT_EN | pac[4] | | | DP_OUT | pa[4] | | | DP_CMPVREF_SEL | N.A. | | | DP_CMP_EN | padier[4] | | | DP_DIN | pa[4] | Table 5.18: Transformation between DP and PA4 | Bit [3:2] of dp_dm_io_ctrl | DM | PA6 | |----------------------------|----------------|-----------| | | DM_ISINK_EN | N.A. | | | DM_BUFVREF_SEL | pa[6] | | | DM_BUF_EN | pac[6] | | | DM_TX_EN | 0 | | 01 | DM_OUT_EN | 0 | | | DM_OUT | 0 | | | DM_CMPVREF_SEL | N.A. | | | DM_CMP_EN | padier[6] | | | DM_DIN | pa[6] | | Bit [3:2] of dp_dm_io_ctrl | DM | PA6 | |----------------------------|----------------|-----------| | | DM_ISINK_EN | N.A. | | | DM_BUFVREF_SEL | 0 | | | DM_BUF_EN | 0 | | 10 | DM_TX_EN | pac[6] | | | DM_OUT_EN | 0 | | | DM_OUT | pa[6] | | | DM_CMPVREF_SEL | N.A. | | | DM_CMP_EN | padier[6] | | | DM_DIN | pa[6] | Page 63 of 102 | Bit [3:2] of dp_dm_io_ctrl | DM | PA6 | |----------------------------|----------------|-----------| | | DM_ISINK_EN | N.A. | | | DM_BUFVREF_SEL | 0 | | | DM_BUF_EN | 0 | | | DM_TX_EN | 0 | | 11 | DM_OUT_EN | pac[6] | | | DM_OUT | pa[6] | | | DM_CMPVREF_SEL | N.A. | | | DM_CMP_EN | padier[6] | | | DM_DIN | pa[6] | Table 5.19: Transformation between DM and PA6 | DP Status | pa[4] | pac[4] | padier[4] | |---------------------------------|------------|--------|-----------| | Bit [1:0] of dp_dm_io_ctrl = 01 | | | | | Output High (3.3V) | 1 | 1 | Х | | Output Low (0.6V) | 0 | 1 | Х | | Input High (> V <sub>th</sub> ) | 1 | 0 | 1 | | Input Low (< V <sub>th</sub> ) | 0 | 0 | 1 | | Output Hi-Z | Х | 0 | Х | | Input Hi-Z | Х | Х | 0 | | Bit [1:0] of dp_dm_io_ | _ctrl = 10 | | | | Output High (3.3V) | 1 | 1 | Х | | Output Low (0V) | 0 | 1 | Х | | Input High (> V <sub>th</sub> ) | 1 | 0 | 1 | | Input Low (< V <sub>th</sub> ) | 0 | 0 | 1 | | Output Hi-Z | Х | 0 | Х | | Input Hi-Z | Х | Х | 0 | | Bit [1:0] of dp_dm_io_ | _ctrl = 11 | | | | Output High (5V) | 1 | 1 | Х | | Output Low (0V) | 0 | 1 | Х | | Input High (> Vth) | 1 | 0 | 1 | | Input Low (< V <sub>th</sub> ) | 0 | 0 | 1 | | Output Hi-Z | Х | 0 | Х | | Input Hi-Z | Х | Х | 0 | Note: V<sub>th</sub> is decided by DP\_CMPVREF\_SEL. Table 5.20: Relationship between DP Status and PA4 Register Setting | DM Status | pa[6] | pac[6] | padier[6] | |---------------------------------|------------|--------|-----------| | Bit [3:2] of dp_dm_io_ctrl = 01 | | | | | Output High (3.3V) | 1 | 1 | X | | Output Low (0.6V) | 0 | 1 | Х | | Input High (> V <sub>th</sub> ) | 1 | 0 | 1 | | Input Low (< V <sub>th</sub> ) | 0 | 0 | 1 | | Output Hi-Z | Х | 0 | Х | | Input Hi-Z | Х | Х | 0 | | Bit [3:2] of dp_dm_io_ctrl = 10 | | | | | Output High (3.3V) | 1 | 1 | Х | | Output Low (0V) | 0 | 1 | Х | | Input High (> V <sub>th</sub> ) | 1 | 0 | 1 | | Input Low (< V <sub>th</sub> ) | 0 | 0 | 1 | | Output Hi-Z | Х | 0 | Х | | Input Hi-Z | Х | Х | 0 | | Bit [3:2] of dp_dm_io_ | _ctrl = 11 | | | | Output High (5V) | 1 | 1 | Х | | Output Low (0V) | 0 | 1 | Х | | Input High (> V <sub>th</sub> ) | 1 | 0 | 1 | | Input Low (< V <sub>th</sub> ) | 0 | 0 | 1 | | Output Hi-Z | Х | 0 | Х | | Input Hi-Z | Х | X | 0 | Note: Vth is decided by DM\_CMPVREF\_SEL Table 5.21: Relationship between DM Status and PA6 Register Setting #### 5.13.3.4 CC1 and CC2 Control The CC macro provides all necessary functions for the application of the USB PD specification. Fig. 5.20 shown in the section 15.3.2 depicts the related hardware components. The CC macro comprises a PD data stream path (BMC\_TX and BMC\_RX), two voltage comparators with 0.66V and 1.23V reference voltage individually for the USB Type-C 5V/1.5A and 5V/3A application, a CC1/CC2 attached detection circuit, and two Rd pulldown resistors for CC1 and CC2 pins. #### 5.13.3.4.1 USB PD Data Stream Path The BMC\_TX and BMC\_RX are designed individually for a transmitter and receiver which comprise the data stream path of the USB PD communication. The BMC\_TX transmits the BMC encoding bit stream from the PD PHY controller. A precise 1.125V output voltage can be trimmed in mass production through searching for the best trimming value of Bandgap reference voltage specified in bit 7:3 of bgtrm register. The BMC\_RX decodes the incoming data on the CC wire, and these decoding data will be transferred to the PD PHY controller further. The BMCTX\_EN signal is used to enable the BMC\_TX transmitter, and the BMCTX\_DOUT signal is used as the transmitted data. The BMCRX\_EN signal is used to enable the BMC\_RX receiver, and the BMC\_BIT presents the decoding output value of the BMC\_RX. In the normal operation mode, all signals mentioned above are under the control of the PD PHY controller. However, these signals also can be managed directly by register access mode. All fields with the same naming in the cc\_misc register can be used to access these signals. How to control this register, please see the related programming sequence in the section 5.12.4.7 for further details, in addition, an external loopback testing also provides a diagnostic mode for both BMC\_TX and BMC\_RX. Please see section 5.12.3.9 about external loopback testing introduction and section 5.12.4.6 about programming sequence example. #### 5.13.3.4.2 USB Type-C 5V/1.5A and 5V/3A Detection There are two independent voltage comparators in the CC macro used for the Type-C 5V/1.5A and 5V/3A detection. One comparator with 0.66V reference voltage is used for 5V/1.5A application, and another with 1.23V is for 5V/3A application. The CC\_CMPSNKXA\_EN of cc\_stat register is used to enable these two comparators. The CC\_SNK1P5A and CC\_SNK3P0A of cc\_stat register are used to represent the output status of these two comparators individually. #### 5.13.3.4.3 CC1/CC2 Attached Detection There are two independent CC attached detection circuits in the CC macro for the CC1 and CC2 pins individually. Each is composed of one comparator with 0.2V reference voltage and one sampling latch for sampling and storing the output value of the voltage comparator. The CC\_CMPRA\_EN of cc\_ctrl register is used to enable these two comparators. And, the CC1\_ATT and CC2\_ATT of cc\_ctrl register are used to represent the individual output status of these two sampling latches. The sampling operation of the latch is defined in the CC\_CMPRA\_LAT of cc\_ctrl register, and the reset control of the latch is defined in the CC\_REGRA\_RESB of cc\_ctrl register. The following programming sequence shows how to detect the CC wire attached: Step 1 Set CC\_CMPRA\_EN of cc\_ctrl register to enable two voltage comparators. **Step 2** Set 1 first, then set 0 to the *CC\_CMPRA\_LAT* of *cc\_ctrl* register to sample and hold the output value of these two comparators simultaneously. **Step 3** Read the *CC1\_ATT* and *CC2\_ATT* of *cc\_ctrl* register to decide which active pin is connecting to the USB cable. Table 5.22 shown below explains the attached detection result by reading the status of both CC1\_ATT and CC2\_ATT2. | CC1_ATT | CC2_ATT | Description | |---------|---------|--------------| | 0 | 0 | Reset value | | 1 | 0 | CC1 attached | | 0 | 1 | CC2 attached | | 1 | 1 | N.A. | Table 5.22: Attached Detection Result by the Status of CC1\_ATT and CC2\_ATT2 #### 5.14 GATE Pin Control and Connection ### 5.14.1 Function Description One particular GATE pin is designed to manage the power delivery for the fast charging application. It can be connected to an external power MOSFET to turn on/off power line. The bit0 of misc2 register is used to control the GATE pin. Table 5.23 shown below describes this IO output characteristics. In addition, the GATE pin has the following features: - (1) Open-drain IO with 20mA sink current capability at $V_{OL} = 0.5V$ . - (2) Supports 21V high voltage tolerance. | Bit0 of misc2 | Gate Pin | | |---------------|-------------------------------|--| | 0 | Output Floating (Reset Value) | | | 1 | Output 0V | | Table 5.23: GATE Pin Output Characteristics ### **5.14.2 GATE Pin Application Connection** Fig. 5.21 illustrates a power management application and the external connection of one power MOSFET. During power on reset, the output status of the GATE pin is floating, which disable the external MOSFET. In the meanwhile, no current can flow from VBUS to VGATE. Set 1 to the bit0 of misc2 register to force the GATE pin to output a zero voltage, which turn on the P-Channel MOSFET and allow the flow of charging current from VBUS to VGATE. Fig. 5.21: GATE Pin Application Connection ### 5.15 VBUS (VDD) Voltage Comparator ### **5.15.1 Function Description** One VBUS (VDD) comparator with a fixed 7V reference voltage is designed for the particular charging specification application. The bit3 of misc2 register is used to enable the voltage comparator. And, the compare result can be read through the bit7 of misc2 register. ### 6. IO Registers ### 6.1. ACC Status Flag Register (flag), IO address = 0x00 | Bit | Reset | R/W | Description | |-------|-------|-----|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 7 - 4 | - | ı | Reserved. Please do not use. | | 3 | 0 | R/W | OV (Overflow Flag). This bit is set to be 1 whenever the sign operation is overflow. | | 2 | 0 | R/W | AC (Auxiliary Carry Flag). There are two conditions to set this bit, the first one is carry out of low nibble in addition operation and the other one is borrow from the high nibble into low nibble in subtraction operation. | | 1 | 0 | R/W | C (Carry Flag). There are two conditions to set this bit, the first one is carry out in addition operation, and the other one is borrow in subtraction operation. Carry is also affected by shift with carry instruction. | | 0 | 0 | R/W | Z (Zero Flag). This bit will be set when the result of arithmetic or logic operation is zero; Otherwise, it is cleared. | ### 6.2. Reset Control Register (rstc), IO address = 0x01 | Bit | Reset | R/W | Description | |-------|-------|-----|-------------------------------------------------------------------| | 7 | 0 | R/W | External reset (PA5) in test mode Enable. 0 / 1: disable / Enable | | | | | Enable fast Wake up. | | | | | 0: Normal wake up. | | 6 | 0 | R/W | The wake-up time is 1024 ILRC clocks. | | | | | 1: Fast wake up. | | | | | The wake-up time is 16 ILRC clocks. | | | | | Watch dog time out period | | | | | 00: 8k ILRC clock period | | 5 - 4 | 00 | R/W | 01: 16k ILRC clock period | | | | | 10: 64k ILRC clock period | | | | | 11: 256k ILRC clock period | | 3 | 0 | R/W | Reserved | | 2 | 1 | R/W | LVR Reset Enable. 0 / 1: disable / enable | | 1 | 1 | R/W | Watch Dog Enable. 0 / 1: disable / enable | | 0 | 0 | R/W | Pin PA5/PRSTB function. 0 / 1: PA5 / PRSTB | ### 6.3. Stack Pointer Register (sp), IO address = 0x02 | Bit | Reset | R/W | Description | |-------|-------|-----|---------------------------------------------------------------------------------------------------| | 7 - 0 | - | R/W | Stack Pointer Register. Read out the current stack pointer, or write to change the stack pointer. | ### 6.4. Clock Mode Register (clkmd), IO address = 0x03 | Bit | Reset | R/W | Description | |-------|-------|-----|-----------------------------------------------------| | | | | System clock ratio | | | | | 00: System clock / 1 | | 7 - 6 | 00 | R/W | 01: System clock / 2 | | | | | 10: System clock / 4 | | | | | 11: System clock / 8 | | 5 | 0 | R/W | System clock source selection. 0 / 1: ILRC / IHRC | | 4 - 2 | - | R/W | Reserved | | 1 | 1 | R/W | Internal High RC Enable. 0 / 1: disable / enable | | 0 | 0 | R/W | Internal Low RC mode selection. 0 / 1: ILRC / NILRC | ### 6.5. Interrupt Enable Register (*inten*), IO address = 0x04 | Bit | Reset | R/W | Description | |-----|-------|-----|--------------------------------------------------------| | 7 | 0 | R/W | Reserved | | 6 | 0 | R/W | Reserved | | 5 | 0 | R/W | Enable interrupt from Timer2. 0 / 1: disable / enable | | 4 | 0 | R/W | Reserved | | 3 | 0 | R/W | Reserved | | 2 | 0 | R/W | Enable interrupt from Timer16. 0 / 1: disable / enable | | 1 | 0 | R/W | Enable interrupt from PD_PHY. 0 / 1: disable / enable | | 0 | 0 | R/W | Enable interrupt from PA0. 0 / 1: disable / enable | ### 6.6. Interrupt Request Register (intrq), IO address = 0x05 | Bit | Reset | R/W | Description | |-----|-------|-----|-------------------------------------------------------------------------------------------------------------------| | 7 | - | R/W | Reserved | | 6 | - | R/W | Reserved | | 5 | - | R/W | Interrupt Request from Timer2, this bit is set by hardware and cleared by software. 0 / 1: No request / Request | | 4 | - | R/W | Reserved | | 3 | - | R/W | Reserved | | 2 | - | R/W | Interrupt Request from Timer16, this bit is set by hardware and cleared by software. 0 / 1: No request / Request | | 1 | - | R/W | Interrupt Request from PD_PHY, this bit is set by hardware and cleared by software. 0 / 1: No request / Request | | 0 | - | R/W | Interrupt Request from pin PA0, this bit is set by hardware and cleared by software. 0 / 1: No Request / request | ### 6.7. LVR Reset Control Register (Ivrc), IO address = 0x08 | Bit | Reset | R/W | Description | |-------|-------|-----|------------------------------| | | | | LVR reset voltage selection. | | | | | 0000: 1.8 V | | | | | 0001: 1.9 V | | | | | 0010: 2.0 V | | | | | 0011: 2.1 V | | | | | 0100: 2.2 V | | | | | 0101: 2.3 V | | | | | 0110: 2.4 V | | 7 – 4 | 0000 | WO | 0111: 2.5 V | | | | | 1000: 2.7 V | | | | | 1001: 3.0 V | | | | | 1010: 3.15V | | | | | 1011: 3.3 V | | | | | 1100: 3.5 V | | | | | 1101: 3.75V | | | | | 1110: 4.0 V | | | | | 1111: 4.5 V | | 3 – 0 | - | WO | Reserved | 6.8. Interrupt Edge Select Register (integ), IO address = 0x09 | Bit | Reset | R/W | Description | |-------|-------|-------|--------------------------------------------------------------------------------| | 7 - 5 | - | - | Reserved | | | | | Timer16 edge selection. | | 4 | 0 | WO | 0 : rising edge of the selected bit to trigger interrupt | | | | | 1 : falling edge of the selected bit to trigger interrupt | | 3 - 2 | - | - | Reserved | | | | 00 WO | PA0 edge selection. | | 1 - 0 | 00 | | 00: both rising edge and falling edge of the selected bit to trigger interrupt | | 1 - 0 | | VVO | 01: rising edge of the selected bit to trigger interrupt | | | | | 10 / 11: falling edge of the selected bit to trigger interrupt | ### 6.9. Timer16 mode Register (t16m), IO address = 0x0B | Bit | Reset | R/W | Description | |-------|-------|---------|-------------------------------------------| | 7 - 5 | | | Timer16 Clock source selection. | | | | | 000: disable | | | 000 | 000 R/W | 001: CLK (system clock) | | | | | 010: reserved | | | | | 100: IHRC | | | | | 110: ILRC | | | | | 111: PA0 falling edge (from external pin) | | 4 - 3 | 00 | R/W | Timer16 clock pre-divider. | | 4 - 3 | 00 | Γ\/ V V | 00: ÷1 | | Bit | Reset | R/W | Description | |-------|-------|-----|----------------------------------------------------------------------------------------------| | | | | 01: ÷4 | | | | | 10: ÷16 | | | | | 11: ÷64 | | | | | Interrupt source selection. Interrupt event happens when the selected bit status is changed. | | | | | 0 : bit 8 of Timer16 | | | | | 1 : bit 9 of Timer16 | | | | | 2 : bit 10 of Timer16 | | 2 - 0 | 000 | R/W | 3 : bit 11 of Timer16 | | | | | 4 : bit 12 of Timer16 | | | | | 5: bit 13 of Timer16 | | | | | 6: bit 14 of Timer16 | | | | | 7: bit 15 of Timer16 | ### 6.10.DP/DM IO Control Register (dp\_dm\_io\_ctrl), IO address = 0x0C | 7 - 4 0000 R/W Reserved DM IO mode switch. | | |-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--| | DM IO mode switch. | | | 0 DM_BUF_EN = DM_BUF_EN 0 DM_BUFVREF_SEL = DM_BUFVREF_SEL 0 DM_TX_EN = DM_DOUT_EN 0 DM_DOUT = DM_DOUT 0 DM_CMP_EN = DM_CMP_EN 0 DM_BUFVREF_SEL = pa[6] 0 DM_BUFVREF_SEL = pa[6] 0 DM_DOUT = 1'b0 0 DM_DOUT = 1'b0 0 DM_DOUT = 1'b0 0 DM_BUFVREF_SEL = 1'b0 0 DM_DOUT_EN padier[6] 0 DM_DOUT_EN = padier[6] 0 DM_DOUT_EN = padier[6] 0 DM_BUFVREF_SEL = 1'b0 0 DM_BUFVREF_SEL = 1'b0 0 DM_BUFVREF_SEL = 1'b0 0 DM_BUFVREF_SEL = 1'b0 0 DM_DOUT_EN = padier[6] 0 DM_DOUT_EN = padier[6] 0 DM_DOUT_EN = padier[6] 0 DM_DOUT_EN = padier[6] 0 DM_DOUT_EN = padier[6] | | | Bit | Reset | R/W | | Description | | | | |-------|-------|-----|------|------------------|------------------|--|--| | | | | DP I | O mode switch. | | | | | | | | | O_DP_BUF_EN | = DP_BUF_EN | | | | | | | | O_DP_BUFVREF_SEL | = DP_BUFVREF_SEL | | | | | | | 00 | O_DP_TX_EN | = DP_TX_EN | | | | | | | 00 | O_DP_DOUT_EN | = DP_DOUT_EN | | | | | | | | O_DP_DOUT | = DP_DOUT | | | | | | | | O_DP_CMP_EN | = DP_CMP_EN | | | | | | | | O_DP_BUF_EN | = pac[4] | | | | | | | | O_DP_BUFVREF_SEL | = pa[4] | | | | | | | 01 | O_DP_TX_EN | = 1'b0 | | | | | | R/W | | O_DP_DOUT_EN | = 1'b0 | | | | | | | | O_DP_DOUT | = 1'b0 | | | | 1 - 0 | 00 | | | O_DP_CMP_EN | = padier[4] | | | | | | | 10 | O_DP_BUF_EN | = 1'b0 | | | | | | | | O_DP_BUFVREF_SEL | = 1'b0 | | | | | | | | O_DP_TX_EN | = pac[4] | | | | | | | | O_DP_DOUT_EN | = 1'b0 | | | | | | | | O_DP_DOUT | = pa[4] | | | | | | | | O_DP_CMP_EN | = padier[4] | | | | | | | 11 | O_DP_BUF_EN | = 1'b0 | | | | | | | | O_DP_BUFVREF_SEL | = 1'b0 | | | | | | | | O_DP_TX_EN | = 1'b0 | | | | | | | | O_DP_DOUT_EN | = pac[4] | | | | | | | | O_DP_DOUT | = pa[4] | | | | | | | | O_DP_CMP_EN | = padier[4] | | | 6.11.Port A Digital Input Enable Register (padier), IO address = 0x0D | Bit | Reset | R/W | Description | |-------|-------|-----|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 7 - 6 | - | WO | Reserved. (Please keep 00 for future compatibility) | | 5 | 0 | WO | Enable PA5 digital input and wake-up event. 1 / 0: enable / disable. This bit can be set to low to disable wake-up from PA5 toggling from this pin. | | 4 | - | WO | Reserved. | | 3 | 0 | WO | Enable PA3 digital input and wake-up event. 1 / 0: enable / disable. This bit can be set to low to disable wake-up from PA3 toggling from this pin. | | 2 - 1 | - | WO | Reserved. (Please keep 00 for future compatibility) | | 0 | 0 | WO | Enable PA0 digital input, wake-up event and interrupt request. 1 / 0: enable / disable. This bit can be set to low to disable wake-up from PA0 toggling and interrupt request from this pin. | #### 6.12.Port B Digital Input Enable Register (pbdier), IO address = 0x0E | Bit | Reset | R/W | Description | |-------|-------|-----|--------------------------------------------------------------------------------| | 7 - 2 | - | WO | Reserved. (Please keep 00 for future compatibility) | | 4 | 0 | WO | Enable PB1 digital input and wake-up event. 1 / 0: enable / disable. | | 1 | 0 | | This bit can be set to low to disable wake-up from PB1 toggling from this pin. | | | 0 | wo | Enable PB0 digital input and wake-up event. 1 / 0: enable / disable. | | 0 | U | | This bit can be set to low to disable wake-up from PB0 toggling from this pin. | #### 6.13.Port A Data Register (pa), IO address = 0x10 | Bit | Reset | R/W | Description | |-------|-------|-----|--------------------------------------------------| | 7 | - | R/W | Reserved | | 6 - 0 | 0x00 | R/W | Data register for Port A. (PA7 is not available) | #### 6.14.Port A Control Register (pac), IO address = 0x11 | Bit | Reset | R/W | Description | |-------|-------|-----|----------------------------------------------------------------------------------------------| | | | | Port A control registers. This register is used to define input mode or output mode for each | | 7 - 0 | 0x00 | R/W | corresponding pin of port A. 0 / 1: input / output | | | | | Please note: PA5 is an open drain output. PA1, PA2, PA4, PA6, and PA7 are not available. | #### 6.15. Port A Pull-High Register (paph), IO address = 0x12 | Bit | Reset | R/W | Description | |-------|-------|-----|--------------------------------------------------------------------------------------------------| | | 0x00 | R/W | Port A pull-high register. This register is used to enable the internal pull-high device on each | | 7 - 0 | | | corresponding pin of port A and this pull high function is active only for input mode. | | 7 - 0 | | | 0 / 1 : disable / enable | | | | | PA1, PA2, PA4, PA6, and PA7 are not available. | #### 6.16. Port A Pull-Low Register (papl), IO address = 0x13 | Bit | Reset | R/W | Description | |-------|-------|-----|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | | 0x00 | R/W | Port A pull-low register. This register is used to enable the internal pull-low device on each corresponding pin of port A and this pull low function is active only for input mode. | | 7 - 0 | | | 0 / 1 : disable / enable | | | | | PA1, PA2, PA4, PA6, and PA7 are not available. | #### 6.17. Port B Data Register (pb), IO address = 0x14 | Bit | Reset | R/W | Description | |-------|-------|-----|-------------------------------------------------------------| | 7 - 2 | - | R/W | Reserved | | 1 - 0 | 00 | R/W | Data register for Port B. (Only PB0 and PB1 are available.) | #### 6.18. Port B Control Register (pbc), IO address = 0x15 | Bit | Reset | R/W | Description | |-------|-------|-----|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 7 - 2 | - | R/W | Reserved | | 1 - 0 | 00 | R/W | Port B control register. This register is used to define input mode or output mode for each corresponding pin of port B. 0 / 1: input / output Only PB0 and PB1 are available. | ### 6.19. Port B Pull-High Register (pbph), IO address = 0x16 | Bit | Reset | R/W | Description | |-------|--------|-------|------------------------------------------------------------------------------------------------------------------| | 7 – 2 | - | R/W | Reserved. | | 4 0 | 4 0 00 | D.444 | Port B pull-high register. This register is used to enable the internal pull-high device on each | | 1 – 0 | 00 | R/W | corresponding pin of port B and this pull high function is active only for input mode. 0 / 1 : Disable / Enable | #### 6.20. Port B Pull-Low Register (pbpl), IO address = 0x17 | Bit | Reset | R/W | Description | |-------|-------|-----|------------------------------------------------------------------------------------------------| | 7 – 2 | ı | R/W | Reserved | | | | | Port B pull-low register. This register is used to enable the internal pull-low device on each | | 1 – 0 | 00 | R/W | corresponding pin of port B and this pull low function is active only for input mode. | | | | | 0 / 1 : Disable / Enable | #### 6.21. Timer2 PWM Control Register (tpw2c), IO address = 0x1A | 0.21 | . I IIII EI Z | Z P VVIVI | Control Register ( <i>tpw2c</i> ), IO address = 0x1A | |-------|---------------|-----------|------------------------------------------------------| | Bit | Reset | R/W | Description | | | | | Timer2 PWM Disable/ Enable | | 7 | 0 | R/W | 0 : TPW2 Disable | | | | | 1 : TPW2 Enable | | | | | Timer2 PWM mode selection. | | 6 | 0 | R/W | 0 : Period mode | | | | | 1 : PWM mode | | | | | Timer2 PWM clock source selection. | | | | | 00 : IHRC | | 5 - 4 | 00 | R/W | 01 : IHRC * 2 | | | | | 10 : Reserved | | | | | 11 : ILRC | | | | | Timer2 PWM clock pre-scalar. | | | | | 00 : ÷ 1 | | 3 - 2 | 00 | R/W | 01 : ÷ 4 | | | | | 10 : ÷ 16 | | | | | 11 : ÷ 64 | | | | | Timer2 PWM resolution selection. | | | | | 00 : 8-bit | | 1 - 0 | 00 | R/W | 01 : 7-bit | | | | | 10 : 6-bit | | | | | 11 : Reserved | ### 6.22. Timer2 PWM Scalar Register (tpw2s), IO address = 0x1B | Bit | Reset | R/W | Description | |-------|-------|-----|------------------------------------------------------| | | | | Inverse the polarity of result output of Timer2 PWM. | | 7 | 0 | R/W | 0: polarity is NOT inversed | | | | | 1: polarity is inversed | | | | | Timer2 PWM output port selection. | | | | | 00 : TPW2 output disable | | 6 - 5 | 00 | R/W | 01 : Reserved | | | | | 10 : TPW2 output to PA3 | | | | | 11 : Reserved | | 4 - 0 | 0x00 | R/W | Timer2 PWM clock scalar. | ### 6.23. Timer2 PWM Bound Register (tpw2b), IO address = 0x1C | Bit | Reset | R/W | Description | |-------|-------|-----|----------------------------| | 7 - 0 | 0x00 | WO | Timer2 PWM bound register. | #### 6.24. Operation Register (opr1), IO address = 0x1D | | • | | | |-------|-------|-----|---------------------------------------------------------| | Bit | Reset | R/W | Description | | 6 - 4 | 000 | R/W | Output probe signal. 000 : Disable output probe signal | | | | | 001 : Output PD PHY probe signal | ### 6.25. Miscellaneous Register (misc2), IO address = 0x1F | Bit | Reset | R/W | Description | |-----|-------|-------|----------------------------------------------| | | | | VBUS (VDD) Voltage Comparator Output. | | 7 | 0 | RO | 0: VBUS (VDD) < 7V | | | | | 1: VBUS (VDD) > 7V | | | | | ILRC switch in stopsys mode | | 6 | 0 | R/W | 0: Disable | | 0 | U | FX/VV | 1: Enable | | | | | Note: Please make sure to set it to Disable. | | | | | LVR switch in stopsys mode | | 5 | 0 | R/W | 0: Disable | | | | | 1: Enable | | | | | Note: Please make sure to set it to Disable. | | | 1 | R/W | LVR power switch | | 4 | | | 0: Off | | _ | | | 1: On (Note) | | | | | Note: Please make sure to set it to ON. | | | | | VBUS (VDD) Voltage Comparator Control. | | 3 | 1 | R/W | 0: Disable | | | | | 1: Enable | | | | | PD CTRL frequency 6MHz and 3MHz switch | | 2 | 1 | R/W | 0 : Disable | | | | | 1 : Enable | | Bit | Reset | R/W | Description | |-----|-------|-----|--------------------------------| | | | | PD CTRL frequency 12MHz switch | | 1 | 1 | R/W | 0 : Disable | | | | | 1 : Enable | | | | | GATE Drive Control: | | 0 | 0 | R/W | 0 : Disable (Output Floating) | | | | | 1 : Enable (Output 0V) | #### 6.26. PD PHY FIFO Register (pd fifo), IO address = 0x30 | Bit | Reset | R/W | Description | |-------|-------|-----|------------------------------------------------------------------------------------| | | - | R/W | FIFO_DATA: | | 7 - 0 | | | One 4-byte FIFO is used for PD PHY TX/RX data storage. | | 7-0 | | | In TX mode (WO): used to write the data payload of a PD SOP packet. | | | | | In RX mode (RO): used to read the received packet data, including 32-bit CRC data. | ### 6.27. PD PHY Status Register (pd\_stat), IO address = 0x31 | Bit | Reset | R/W | Description | |-----|-------|-----|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 7 | - | - | Reserved | | 6 | 1 | RO | STATUS_IDLE: Reveal the USB CC wire status. It is used to avoid a signal collision occurrence on the CC wire. User must assure that the bus is at the idle status before starting to transmit data. 0: Bus Active 1: Bus Idle | | 5 | 0 | RO | STATUS_HDRST: PD PHY controller has received one Hard Reset signaling successfully. This bit is valid only when both RX_FINISH and RX_SUCCESS are active. Auto-Clear when enabling RX_CLR or disabling PHYCTRL_EN of pd_txrx register. 0: Receive one PD SOP packet 1: Receive one PD Hard Reset signaling | | 4 | 0 | RO | FIFO_FULL: Reveal PD PHY FIFO (pd_fifo register) status. Restore to the default value when enabling RX_CLR or disabling PHYCTRL_EN of pd_txrx register. 0: Non-Full 1: Full | | 3 | 1 | RO | FIFO_EMPTY: Reveal PD PHY FIFO (pd_fifo register) status. Restore to the default value when enabling RX_CLR or disabling PHYCTRL_EN of pd_txrx register. 0: Non-Empty 1: Empty | | 2 | 0 | RO | RX_SUCCESS: PD PHY controller has received one packet or signaling successfully. This bit is valid only when RX_FINISH is active. | | Bit | Reset | R/W | Description | |-----|-------|-----|-----------------------------------------------------------------------------------------------| | | | | Auto-Clear when enabling RX_CLR or disabling PHYCTRL_EN of pd_txrx register. | | | | | 0: RX Fail (This received data may be illegal or broken, and it should be ignored.) | | | | | 1: RX Success | | | | | RX_FINISH: | | | | | PD PHY controller has finished one packet or signaling reception. | | 1 | 0 | RO | Auto-Clear when enabling RX_CLR or disabling PHYCTRL_EN of pd_txrx register. | | | | | 0: RX Busy if PD PHY controller is starting to receive a packet. | | | | | 1: RX Finish | | | | | TX_FINISH: | | | | | PD PHY controller has finished one packet or signaling transmission successfully. | | | | | Auto-Clear when enabling TX_CLR or disabling PHYCTRL_EN of pd_txrx register. | | 0 | 0 | RO | Note: If PD PHY controller is starting to receive a packet unexpectedly, this bit will not be | | | | | active and this packet transmission will be cancelled. | | | | | 0: TX Busy if TX_START of pd_txrx register has been enabled. | | | | | 1: TX Finish | # 6.28. PD PHY TXRX Register (pd\_txrx), IO address = 0x32 | Bit | Reset | R/W | Description | |-----|-------|-----|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 7 | 0 | RW | SEND_BIST: Enable PD PHY controller to send a continuous BIST test signal on the CC wire for TX eye diagram measurement. 0: Disable 1: Enable | | 6 | 0 | RW | SEND_HDRST: Enable PD PHY controller to send one Hard Reset signaling on the CC wire. 0: Disable 1: Enable | | 5 | 0 | RW | PHYCTRL_EN: Enable PD PHY controller. Note: When user disable the PD PHY controller, the following signal will be also cleared simultaneously: (1) TX_FINISH, RX_FINISH, RX_SUCCESS and STATUS_HDRST of pd_stat register (2) PD PHY interrupt signal (3) FIFO_EMPTY and FIFO_FULL of pd_stat register restores to the default value 0: Disable 1: Enable | | 4 | 0 | RW | TX_START: Enable PD PHY controller to transmit a packet or signaling, including the BIST signaling. 0: No effect 1: Enable (Auto-Clear after enabling this bit) | | 3 | 0 | RW | RX_CLR: User must set this bit to clear all RX status and PD PHY interrupt after PD PHY controller has | | Bit | Reset | R/W | Description | |-----|-------|------|-------------------------------------------------------------------------------------------------------| | | | | finished a packet or signaling reception. When this bit is enabled, the following signal will be | | | | | also cleared simultaneously: | | | | | (1) RX_FINISH, RX_SUCCESS and STATUS_HDRST of pd_stat register | | | | | (2) PD PHY interrupt signal | | | | | (3) FIFO_EMPTY and FIFO_FULL of pd_stat register restores to the default value | | | | | 0: No effect | | | | | 1: Enable (Auto-Clear after enabling this bit) | | | | | TX_CLR: | | | | | User must set this bit to clear all TX status and PD PHY interrupt after PD PHY controller has | | | 0 | RW | finished a packet or signaling transmission. When this bit is enabled, the following signals | | 2 | | | will be also cleared simultaneously: | | | | | (1) TX_FINISH of pd_stat register | | | | | (2) PD PHY interrupt signal | | | | | 0: No effect | | | | | 1: Enable (Auto-Clear after enabling this bit) | | | | | FIFO_RO: | | 1 | 0 | RW | User must update the read index pointer of the PD PHY FIFO after reading one byte from | | | | IXVV | FIFO (pd_fifo register). A correct operation is "write 1 first, then write 0" or "write 0 first, then | | | | | write 1" (rising-edge trigger mode). | | | | | FIFO_WR: | | 0 | 0 | 0 RW | User must update the write index pointer of the PD PHY FIFO after writing one byte into | | | | | FIFO (pd_fifo register). A correct operation is "write 1 first, then write 0" or "write 0 first, then | | | | | write 1" (rising-edge trigger mode). | # 6.29. PD PHY Control Register ( $pd_ctrl$ ), IO address = 0x33 | Bit | Reset | R/W | Description | |-----|-------|-----|----------------------------------------------------------------------| | | | RO | RX_REQ: Only used in the internal or external loopback testing mode. | | 7 | 0 | | This bit is valid only when TEST_SEL = 1. | | ' | | | 0: Non-Active | | | | | 1: Active | | | | | RX_ACK: | | | | RW | Only used in the internal or external loopback testing mode. | | 6 | 0 | | This bit is valid only when TEST_SEL = 1. | | | | | 0: Non-Active | | | | | 1: Active | | | | | LOOP_SEL: | | | | RW | Select internal or external loopback testing. | | 5 | 0 | | This bit is valid only when TEST_SEL = 1. | | | | | 0: Select external loopback testing | | | | | 1: Select internal loopback testing | | 4 | 0 | RW | TEST_SEL: | | | J | | Turn on the data path of internal/external loopback testing. | | Bit | Reset | R/W | Description | |-----|-------|-------|-------------------------------------------------------------------------------------------------------------------------------------| | | | | 0: Disable | | | | | 1: Enable | | | | | PROBE_SEL: | | | | | Select the inner signal of PD PHY controller onto the specified GPIO pins when all related | | | | | GPIO pins have been switched to the probe mode. These signals are useful for debugging protocol errors during software development. | | 3:2 | 0 | RW | Note: These bits are valid only when bit [6:4] of opr1 register = 001 (Output PD PHY probe signal). | | | | | 00: int_pd_phy, st_phy[2:0] | | | | | 01: fifo_ov, STATUS_HDRST, RX_SUCCESS, RX_FINISH | | | | | 10: FIFO_FULL, FIFO_EMPTY, TX_FINISH, STATUS_IDLE | | | | | 11: crc_cmp_out, sym_eop, pktdet_fail, BMC_BIT | | | 0 | RW | DIS_RX: | | 1 | | | PD PHY controller automatically turn off the received data path during transmitting data. | | ' | | 1 ( ) | 0: Disable | | | | | 1: Enable | | | | | CC_SEL: | | | | | Obtain the control of transmitted and received data paths from the PD PHY controller. | | 0 | 0 | RW | 0: Disable (PD PHY controller manages all TX/RX data paths automatically.) | | | | | 1: Enable (User can control the entire data communication by setting BMCRX_EN, | | | | | BMCTX_EN and BMCTX_DOUT of cc_misc register.) | #### 6.30. PD PHY Decoder Register (pd decoder), IO address = 0x34 | Bit | Reset | R/W | Description | |-----|-------|-----|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 7:5 | 4 | RW | TH_LOW: Used to adjust the PD PHY data receiving capability. Threshold selection of low-voltage signal length of BMC decoding: 000: 11T Clock Time (166.66ns X 11) 001: 12T Clock Time (166.66ns X 12) 010: 13T Clock Time (166.66ns X 13) 011: 14T Clock Time (166.66ns X 14) 100: 15T Clock Time (166.66ns X 15) 101: 16T Clock Time (166.66ns X 16) 110: 17T Clock Time (166.66ns X 17) 111: 18T Clock Time (166.66ns X 18) | | 4:2 | 4 | RW | TH_HIGH: Used to adjust the PD PHY data receiving capability. Threshold selection of high-voltage signal length of BMC decoding: 000: 11T Clock Time (166.66ns X 11) 001: 12T Clock Time (166.66ns X 12) 010: 13T Clock Time (166.66ns X 13) 011: 14T Clock Time (166.66ns X 14) 100: 15T Clock Time (166.66ns X 15) 101: 16T Clock Time (166.66ns X 16) 110: 17T Clock Time (166.66ns X 17) 111: 18T Clock Time (166.66ns X 18) | | Bit | Reset | R/W | Description | |-----|-------|-----|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 1:0 | 1 | RW | TH_DEB: Used to adjust the PD PHY data receiving capability. Debounce time selection for the received data on the CC wire: 00: Deglitch 1T Clock Time (166.66ns X 1) 01: Deglitch 2T Clock Time (166.66ns X 2) 10: Deglitch 3T Clock Time (166.66ns X 3) 11: Deglitch 4T Clock Time (166.66ns X 4) | # 6.31. DP Output Register (dp\_out), IO address = 0x38 | Bit | Reset | R/W | Description | |-----|-------|------|------------------------------------------------------------------------------------------------------------| | 7:6 | - | - | Reserved | | | | | DP_ISINK_EN: Enable DP sink current path (25uA~175uA, weak pulldown). | | | | | Note: Strongly suggest that it should be turned off after system startup. Its function is only | | 5 | 1 | RW | used for providing an initial value on the DP pin, which preventing the unknown state from | | | | | entering system operation. | | | | | 0: Disable | | | | | 1: Enable | | | | | DP_BUFVREF_SEL: | | 4 | 0 | RW | Voltage selection of DP drive buffer; this bit is valid only when DP_BUF_EN = 1. | | 4 | | IXVV | 0: 0.6V | | | | | 1: 3.3V | | | | | DP_BUF_EN: | | 3 | 0 | RW | Enable DP drive buffer. | | 3 | | IXVV | 0: Disable | | | | | 1: Enable | | | | | DP_TX_EN: | | 2 | 0 | RW | Enable DP drive buffer. | | _ | | | 0: Disable | | | | | 1: Enable | | | | | DP_OUT_EN: | | 1 | 0 | RW | Enable DP digital output. | | | | 100 | 0: Disable | | | | | 1: Enable | | | | | DP_OUT: | | | | | DP drive voltage selection; this bit is valid only when DP_OUT_EN or DP_TX_EN = 1. | | | _ | | 0: 0V when DP_OUT_EN or DP_TX_EN = 1 | | 0 | 0 | RW | 1: (1) 5V when DP_OUT_EN = 1 (Note) | | | | | (2) 3.3V when DP_TX_EN = 1 | | | | | Note: Actual output voltage is decided by a 5V Regulator output (V <sub>REG</sub> ). An additional voltage | | | | | drop can cause the DP drive voltage less than the expected value (5V). | ### 6.32. DP Input Register $(dp_in)$ , IO address = 0x39 | Bit | Reset | R/W | Description | |-----|-------|-------|-------------------------------------------------------| | 7:4 | - | - | Reserved | | | | | DP_CMPVREF_SEL: | | | | | Reference voltage selection of DP voltage comparator. | | 3:2 | 2 | RW | 00: 0.35V | | 3.2 | 2 | IXVV | 01: 1.2V | | | | | 10: 2.4V | | | | | 11: 3.0V | | | | | DP_CMP_EN: | | 1 | 1 | RW | Enable DP voltage comparator. | | ' | ' | KVV | 0: Disable | | | | | 1: Enable | | | | | DP_DIN: | | 0 | 0 | R/O | Output value of DP voltage comparator. | | | | I N/O | 0: Logic Zero | | | | | 1: Logic One | # 6.33. DM Output Register (*dm\_out*), IO address = 0x3A | Bit | Reset | R/W | Description | |-----|-------|-----|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 7:6 | - | - | Reserved | | 5 | 1 | RW | DM_ISINK_EN: Enable DM sink current path (25uA~175uA, weak pulldown). Note: Strongly suggest that it should be turned off after system startup. Its function is only used for providing an initial value on the DM pin, which preventing the unknown state from entering system operation. 0: Disable 1: Enable | | 4 | 0 | RW | DM_BUFVREF_SEL: Voltage selection of DM drive buffer; this bit is valid only when DM_BUF_EN = 1. 0: 0.6V 1: 3.3V | | 3 | 0 | RW | DM_BUF_EN: Enable DM drive buffer. 0: Disable 1: Enable | | 2 | 0 | RW | DM_TX_EN: Enable DM drive buffer. 0: Disable 1: Enable | | 1 | 0 | RW | DM_OUT_EN: Enable DM digital output. 0: Disable 1: Enable | | 0 | 0 | RW | DM_OUT: DM drive voltage selection; this bit is valid only when DM_OUT_EN or DM_TX_EN = 1. | | Bit | Reset | R/W | Description | |-----|-------|-----|------------------------------------------------------------------------------------------------------------| | | | | 0: 0V when DM_OUT_EN or DM_TX_EN = 1 | | | | | 1: (1) 5V when DM_OUT_EN = 1 (Note) | | | | | (2) 3.3V when DM_TX_EN = 1 | | | | | Note: Actual output voltage is decided by a 5V Regulator output (V <sub>REG</sub> ). An additional voltage | | | | | drop can cause the DM drive voltage less than the expected value (5V). | ### 6.34. DM Input Register (dm\_in), IO address = 0x3B | Bit | Reset | R/W | Description | |-----|-------|---------------------------------------------------------|-------------------------------------------------------| | 7:4 | - | - | Reserved | | | | | DM_CMPVREF_SEL: | | | | | Reference voltage selection of DM voltage comparator. | | 3:2 | 2 | RW | 00: 0.35V | | 3.2 | | ΓVV | 01: 1.2V | | | | | 10: 2.4V | | | | | 11: 3.0V | | | | | DM_CMP_EN: | | 1 | 1 | RW Enable DM voltage comparator. 0: Disable 1: Enable | Enable DM voltage comparator. | | ' | ' | | 0: Disable | | | | | 1: Enable | | | | | DM_DIN: | | 0 | 0 | R/O | Output value of DM voltage comparator. | | | 0 | 10/0 | 0: Logic Zero | | | | | 1: Logic One | ### 6.35. CC Control Register (cc\_ctrl), IO address = 0x3D | Bit | Reset | R/W | Description | | |-----|-------|---------|----------------------------------------------------------------------------------------------------|--| | 7:5 | - | - | Reserved | | | | | | CC_CMPRA_LAT: Sample CC1/CC2 attached detection comparator output, and save the compare value into | | | | | 514 | the CC1/CC2 sampling latch. | | | 4 | 0 | RW | Note: Correct operation is "Write 1 first, then write 0". | | | | | | 0: Release | | | | | | 1: Latch comparator output | | | | | | CC_REGRA_RESB: | | | 3 | 0 | RW | <u> </u> | | | | | 1 ( ) ( | 0: Reset (Active Low) | | | | | | 1: Release | | | | | RW | CC_CMPRA_EN: | | | 2 | 1 | | Enable CC1/CC2 attached detection comparator. | | | | | | 0: Disable | | | | | | 1: Enable | | | | | | CC2_ATT: | | | 1 | 0 | RO | CC2 sampling latch output. | | | ' | | 1.0 | 0: CC2 attached detection comparator output $<$ 0.2V | | | | | | 1: CC2 attached detection comparator output ≥ 0.2V | | | Bit | Reset | R/W | Description | |-----|-------|-----|-----------------------------------------------------| | | | DO | CC1_ATT: CC1 sampling latch output. | | 0 | 0 | RO | 0: CC1 attached detection comparator output <0.2V | | | | | 1: CC1 attached detection comparator output ≧ 0.2V | ### 6.36. CC Status Register (cc\_stat), IO address = 0x3E | Bit | Reset | R/W | Description | |-----|-------|-----|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 7:3 | - | - | Reserved | | 2 | 0 | RW | CC_CMPSNKXA_EN: Enable two independent CC1/CC2 voltage comparators to detect the USB Type-C current mode. 0: Disable 1: Enable | | 1 | 0 | RO | CC_SNK3P0A: CC1/CC2 voltage comparator output for the USB Type-C 5V/3A detection. 0: CC1/CC2 voltage comparator output <1.23V 1: CC1/CC2 voltage comparator output ≥1.23V | | 0 | 0 | RO | CC_SNK1P5A: CC1/CC2 voltage comparator output for the USB Type-C 5V/1.5A detection. 0: CC1/CC2 voltage comparator output <0.66V 1: CC1/CC2 voltage comparator output ≥0.66V | ### 6.37. CC Miscellaneous Register (cc\_misc), IO address = 0x3F | Bit | Reset | R/W | Description | |-----|-------|-----|-------------------------------------------------------------| | 7:4 | - | - | Reserved | | | | | BMCTX_EN: | | | | | Enable CC1/CC2 digital output. | | 3 | 0 | RW | This bit is valid only when CC_SEL of pd_ctrl register = 1. | | | | | 0: Disable | | | | | 1: Enable | | | | | BMCTX_DOUT: | | | | | CC1/CC2 digital output data. | | 2 | 0 | RW | This bit is valid only when CC_SEL of pd_ctrl register = 1. | | | | | 0: Logic Zero | | | | | 1: Logic One | | | | | BMCRX_EN: | | | | | Enable CC1/CC2 receiver edge detector. | | 1 | 0 | RW | This bit is valid only when CC_SEL of pd_ctrl register = 1. | | | | | 0: Disable | | | | | 1: Enable | | | | | BMC_BIT: | | 0 | 0 | RO | CC1/CC2 receiver edge detector output. | | | | 1.0 | 0: Logic Zero | | | | | 1: Logic One | ### 7. Instructions | Symbol | Description | |----------|-------------------------------------------------------------------------------------------------------| | ACC | Accumulator (Abbreviation of accumulator) | | а | Accumulator (symbol of accumulator in program) | | sp | Stack pointer | | flag | ACC status flag register | | I | Immediate data | | & | Logical AND | | I | Logical OR | | <b>←</b> | Movement | | ٨ | Exclusive logic OR | | + | Add | | _ | Subtraction | | ~ | NOT (logical complement, 1's complement) | | ₹ | NEG (2's complement) | | ov | Overflow (The operational result is out of range in signed 2's complement number system) | | Z | Zero (If the result of ALU operation is zero, this bit is set to 1) | | С | Carry (The operational result is to have carry out for addition or to borrow carry for subtraction in | | C | unsigned number system) | | AC | Auxiliary Carry | | AU | (If there is a carry out from low nibble after the result of ALU operation, this bit is set to 1) | | M.n | Only addressed in 0~0x3F (0~63) is allowed | | IO.n | Only addressed in 0~0x3F (0~63) is allowed | #### 7.1. Data Transfer Instructions | 7.1. | Data III | ansier instructions | | | | |-------|----------|-----------------------------------------------------------------------------|--|--|--| | mov | a, I | Move immediate data into ACC. | | | | | | | Example: mov a, 0x0f; | | | | | | | Result: a ← 0fh; | | | | | | | Affected flags: 『N』Z 『N』C 『N』AC 『N』OV | | | | | mov | М, а | Move data from ACC into memory | | | | | | | Example: mov MEM, a; | | | | | | | Result: MEM ← a | | | | | | | Affected flags: 『N』Z 『N』C 『N』AC 『N』OV | | | | | mov | a, M | Move data from memory into ACC | | | | | | , | Example: mov a, MEM; | | | | | | | Result: a ← MEM; Flag Z is set when MEM is zero. | | | | | | | Affected flags: "Y』Z "N』C "N』AC "N』OV | | | | | mov | a, IO | Move data from IO into ACC | | | | | | | Example: mov a, pa; | | | | | | | Result: a ← pa; Flag Z is set when pa is zero. | | | | | | | Affected flags: "Y』Z "N』C "N』AC "N』OV | | | | | mov | IO, a | Move data from ACC into IO | | | | | | | Example: <i>mov</i> pb, a; | | | | | | | Result: pb ← a | | | | | | | Affected flags: 『N』Z 『N』C 『N』AC 『N』OV | | | | | ldt16 | word | Move 16-bit counting values in Timer16 to memory in word. | | | | | | | Example: <i>ldt16</i> word; | | | | | | | Result: word ← 16-bit timer | | | | | | | Affected flags: 『N』Z 『N』C 『N』AC 『N』OV | | | | | | | | | | | | | | Application Example: | | | | | | | | | | | | | | word T16val ; // declare a RAM word | | | | | | | ologr Ib@ T16val : // clogr T16val /I SP) | | | | | | | clear Ib@ T16val; // clear T16val (LSB) | | | | | | | clear hb@ T16val; // clear T16val (MSB) stt16 T16val; // initial T16 with 0 | | | | | | | | | | | | | | set1 t16m.5; // enable Timer16 | | | | | | | | | | | | | | set0 t16m.5; // disable Timer 16 | | | | | | | Idt16 T16val; // save the T16 counting value to T16val | | | | | | | • | | | | | | | | | | | | | | | | | | | stt16 word | Store 16-bit data from memory in word to Timer16. | | | | | | |----------------------|---------------------------------------------------------------------------------------------------------------|--|--|--|--|--| | Example: stt16 word; | | | | | | | | | Result: 16-bit timer ←word | | | | | | | | Affected flags: 『N』Z 『N』C 『N』AC 『N』OV | | | | | | | | Application Example: | | | | | | | | word T16val ; // declare a RAM word | | | | | | | | | | | | | | | | mov a, 0x34; | | | | | | | | mov lb@ T16val , a; // move 0x34 to T16val (LSB) | | | | | | | | mov a, 0x12; | | | | | | | | mov hb@ T16val , a ; // move 0x12 to T16val (MSB) | | | | | | | | stt16 T16val ; // initial T16 with 0x1234 | | | | | | | | | | | | | | | idxm a, index | Move data from specified memory to ACC by indirect method. It needs 2T to execute this | | | | | | | MAIII a, IIIUEX | instruction. | | | | | | | | Example: idxm a, index; | | | | | | | | Result: a ← [index], where index is declared by word. | | | | | | | | Result: a ← [index], where index is declared by word. Affected flags: 『N』Z 『N』C 『N』AC 『N』OV | | | | | | | | Allected liags. IN 2 IN 0 IN AC IN OV | | | | | | | | Application Example: | | | | | | | | word RAMIndex ; // declare a RAM pointer | | | | | | | | may a OvED : // agains nainter to an address (LCD) | | | | | | | | mov a, 0x5B; // assign pointer to an address (LSB) | | | | | | | | mov lb@RAMIndex, a; // save pointer to RAM (LSB) mov a, 0x00; // assign 0x00 to an address (MSB), should be 0 | | | | | | | | | | | | | | | | mov hb@RAMIndex, a; // save pointer to RAM (MSB) | | | | | | | | idxm a, RAMIndex ; // mov memory data in address 0x5B to ACC | | | | | | | Idxm index, a | Move data from ACC to specified memory by indirect method. It needs 2T to execute this | | | | | | | | instruction. | | | | | | | | Example: idxm index, a; | | | | | | | | Result: [index] ← a; where index is declared by word. | | | | | | | | Affected flags: 『N』Z 『N』C 『N』AC 『N』OV | | | | | | | | Application Example: | | | | | | | | word RAMIndex; // declare a RAM pointer | | | | | | | | | | | | | | | | mov a, 0x5B; // assign pointer to an address (LSB) | | | | | | | | mov lb@RAMIndex, a; // save pointer to RAM (LSB) | | | | | | | | mov a, 0x00; // assign 0x00 to an address (MSB), should be 0 | | | | | | | | mov hb@RAMIndex, a; // save pointer to RAM (MSB) | | | | | | | | | | | | | | | | mov a, 0xA5 ; | | | | | | Page 87 of 102 | | idxm RAMIndex, a ; // mov 0xA5 to memory in address 0x5B | | | | | |------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--| | xch M | Exchange data between ACC and memory Example: xch MEM; Result: MEM ← a , a ← MEM | | | | | | | Affected flags: 『N』Z 『N』C 『N』AC 『N』OV | | | | | | pushaf | Move the <i>ACC</i> and <i>flag</i> register to memory that address specified in the stack pointer. Example: <i>pushaf</i> ; Result: [sp] ← {flag, ACC}; sp ← sp + 2; Affected flags: 『N』Z 『N』C 『N』AC 『N』OV | | | | | | | Application Example: | | | | | | | .romadr 0x10; // ISR entry address | | | | | | | pushaf; // put ACC and flag into stack memory | | | | | | | // ISR program | | | | | | | // ISR program | | | | | | | popaf; // restore ACC and flag from stack memory | | | | | | | reti ; | | | | | | nanaf | Posters ACC and flag from the momentum high address is appointed in the stack pointer | | | | | | popaf | Restore ACC and flag from the memory which address is specified in the stack pointer. Example: popaf; | | | | | | | Result: sp ← sp - 2 ; | | | | | | | {Flag, ACC} ← [sp]; | | | | | | | Affected flags: "Y Z "Y C "Y AC "Y OV | | | | | | 7.2. Arithmo | etic Operation Instructions | | | | | | add a, I | Add immediate data with ACC, then put result into ACC | | | | | | | Example: add a, 0x0f; | | | | | | | Result: a ← a + 0fh | | | | | | - d-d <b>N</b> 4 | Affected flags: "Y Z "Y C "Y AC "Y OV | | | | | | add a, M | Add data in memory with ACC, then put result into ACC | | | | | | | Example: add a, MEM ; Result: a ← a + MEM | | | | | | | Affected flags: "Y Z "Y C "Y AC "Y OV | | | | | | add M, a | Add data in memory with ACC, then put result into memory | | | | | | , | Example: add MEM, a; | | | | | | | Result: MEM ← a + MEM | | | | | | | Affected flags: 『Y』Z 『Y』C 『Y』AC 『Y』OV | | | | | | <i>addc</i> a, M | Add data in memory with ACC and carry bit, then put result into ACC | | | | | | | Example: addc a, MEM; | | | | | | | Result: a ← a + MEM + C | | | | | | | Affected flags: "Y Z "Y C "Y AC "Y OV | | | | | | addc M, a | Add data in memory with ACC and carry bit, then put result into memory | | | | | | | Example: addc MEM, a ; Result: MEM ← a + MEM + C | | | | | | | | | | | | | | Affected flags: 『Y』Z 『Y』C 『Y』AC 『Y』OV | | | | | Page 88 of 102 | addc a | Add carry with ACC, then put result into ACC | | | | | | |------------------|------------------------------------------------------------------------------------------------|--|--|--|--|--| | | Example: addc a; | | | | | | | | Result: a ← a + C | | | | | | | | Affected flags: "Y Z "Y C "Y AC "Y OV | | | | | | | addc M | Add carry with memory, then put result into memory | | | | | | | | Example: addc MEM; | | | | | | | | Result: MEM ← MEM + C | | | | | | | | Affected flags: "Y"Z "Y"C "Y"AC "Y"OV | | | | | | | nadd a, M | Add negative logic (2's complement) of ACC with memory | | | | | | | | Example: nadd a, MEM; | | | | | | | | Result: a ← 〒a + MEM | | | | | | | | Affected flags: 『Y』Z 『Y』C 『Y』AC 『Y』OV | | | | | | | <i>nadd</i> M, a | Add negative logic (2's complement) of memory with ACC | | | | | | | | Example: nadd MEM, a ; | | | | | | | | Result: MEM ← 〒MEM + a | | | | | | | | Affected flags: 『Y』Z 『Y』C 『Y』AC 『Y』OV | | | | | | | sub a, I | Subtraction immediate data from ACC, then put result into ACC. | | | | | | | 23., 1 | Example: sub a, 0x0f; | | | | | | | | Result: $a \leftarrow a - 0$ fh ( $a + [2$ 's complement of 0fh]) | | | | | | | | Affected flags: "Y』Z "Y』C "Y』AC "Y』OV | | | | | | | sub a, M | Subtraction data in memory from ACC, then put result into ACC | | | | | | | | Example: sub a, MEM; | | | | | | | | Result: a ← a - MEM (a + [2's complement of M]) | | | | | | | | Affected flags: "Y』Z "Y』C "Y』AC "Y』OV | | | | | | | <i>sub</i> M, a | Subtraction data in ACC from memory, then put result into memory | | | | | | | | Example: sub MEM, a; Result: MEM ← MEM - a ( MEM + [2's complement of a] ) | | | | | | | | | | | | | | | | Affected flags: "Y Z "Y C "Y AC "Y OV | | | | | | | subc a, M | Subtraction data in memory and carry from ACC, then put result into ACC Example: subc a, MEM; | | | | | | | | Result: a ← a – MEM - C | | | | | | | | Affected flags: "Y_Z "Y_C "Y_AC "Y_OV | | | | | | | subc M, a | Subtraction ACC and carry bit from memory, then put result into memory | | | | | | | , | Example: subc MEM, a; | | | | | | | | Result: MEM ← MEM – a - C | | | | | | | | Affected flags: 『Y』Z 『Y』C 『Y』AC 『Y』OV | | | | | | | subc a | Subtraction carry from ACC, then put result into ACC | | | | | | | | Example: subc a; | | | | | | | | Result: a ← a - C | | | | | | | | Affected flags: "Y』Z "Y』C "Y』AC "Y』OV | | | | | | | subc M | Subtraction carry from the content of memory, then put result into memory | | | | | | | | Example: subc MEM; | | | | | | | | Result: MEM ← MEM - C | | | | | | | | Affected flags: 『Y』Z 『Y』C 『Y』AC 『Y』OV | | | | | | | inc M | Increment the content of memory | | | | | | | | Example: inc MEM; | | | | | | | | Result: MEM ← MEM + 1 | |---------|---------------------------------------| | | Affected flags: 『Y』Z 『Y』C 『Y』AC 『Y』OV | | dec M | Decrement the content of memory | | | Example: dec MEM; | | | Result: MEM ← MEM - 1 | | | Affected flags: 『Y』Z 『Y』C 『Y』AC 『Y』OV | | clear M | Clear the content of memory | | | Example: clear MEM; | | | Result: MEM ← 0 | | | Affected flags: 『N』Z 『N』C 『N』AC 『N』OV | #### 7.3. Shift Operation Instructions | sr a | Shift right of ACC, shift 0 to bit 7 | |--------|------------------------------------------------------------------------------------------------------| | | Example: sr a; | | | Result: a (0,b7,b6,b5,b4,b3,b2,b1) ← a (b7,b6,b5,b4,b3,b2,b1,b0), C ← a(b0) | | | Affected flags: "N Z "Y C "N AC "N OV | | src a | Shift right of ACC with carry bit 7 to flag | | | Example: src a; | | | Result: a $(c,b7,b6,b5,b4,b3,b2,b1) \leftarrow$ a $(b7,b6,b5,b4,b3,b2,b1,b0)$ , C $\leftarrow$ a(b0) | | | Affected flags: 『N』Z 『Y』C 『N』AC 『N』OV | | sr M | Shift right the content of memory, shift 0 to bit 7 | | | Example: sr MEM; | | | Result: MEM(0,b7,b6,b5,b4,b3,b2,b1) ← MEM(b7,b6,b5,b4,b3,b2,b1,b0), C ← MEM(b0) | | | Affected flags: 『N』Z 『Y』C 『N』AC 『N』OV | | src M | Shift right of memory with carry bit 7 to flag | | | Example: src MEM; | | | Result: MEM(c,b7,b6,b5,b4,b3,b2,b1) ← MEM (b7,b6,b5,b4,b3,b2,b1,b0), C ← MEM(b0) | | | Affected flags: 『N』Z 『Y』C 『N』AC 『N』OV | | s/ a | Shift left of ACC shift 0 to bit 0 | | | Example: sl a; | | | Result: a (b6,b5,b4,b3,b2,b1,b0,0) ← a (b7,b6,b5,b4,b3,b2,b1,b0), C ← a (b7) | | | Affected flags: 『N』Z 『Y』C 『N』AC 『N』OV | | slc a | Shift left of ACC with carry bit 0 to flag | | | Example: slc a; | | | Result: a (b6,b5,b4,b3,b2,b1,b0,c) ← a (b7,b6,b5,b4,b3,b2,b1,b0), C ← a(b7) | | | Affected flags: 『N』Z 『Y』C 『N』AC 『N』OV | | s/ M | Shift left of memory, shift 0 to bit 0 | | | Example: sl MEM; | | | Result: MEM (b6,b5,b4,b3,b2,b1,b0,0) ← MEM (b7,b6,b5,b4,b3,b2,b1,b0), C ← MEM(b7) | | | Affected flags: 『N』Z 『Y』C 『N』AC 『N』OV | | slc M | Shift left of memory with carry bit 0 to flag | | | Example: slc MEM; | | | Result: MEM (b6,b5,b4,b3,b2,b1,b0,C) ← MEM (b7,b6,b5,b4,b3,b2,b1,b0), C ← MEM (b7) | | | Affected flags: 『N』Z 『Y』C 『N』AC 『N』OV | | swap a | Swap the high nibble and low nibble of ACC | | | Example: swap a; | | | Result: a (b3,b2,b1,b0,b7,b6,b5,b4) ← a (b7,b6,b5,b4,b3,b2,b1,b0) | | | Affected flags: 『N』Z 『N』C 『N』AC 『N』OV | # 7.4. Logic Operation Instructions | _ | • | | |--------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------|--| | and a, I | Perform logic AND on ACC and immediate data, then put result into ACC | | | | Example: and a, 0x0f; | | | | Result: a ← a & 0fh | | | | Affected flags: "Y Z "N C "N AC "N OV | | | and a, M | Perform logic AND on ACC and memory, then put result into ACC | | | | Example: and a, RAM10; | | | | Result: a ← a & RAM10 | | | | Affected flags: "Y Z "N C "N AC "N OV | | | and M, a | Perform logic AND on ACC and memory, then put result into memory | | | | Example: and MEM, a; | | | | Result: MEM ← a & MEM | | | 1 | Affected flags: "Y Z "N C "N AC "N OV | | | or a, I | Perform logic OR on ACC and immediate data, then put result into ACC | | | | Example: $or$ a, $0x0f$ ;<br>Result: a $\leftarrow$ a 0fh | | | | ' | | | or a, M | Affected flags: "Y』Z "N』C "N』AC "N』OV Perform logic OR on ACC and memory, then put result into ACC | | | Oi a, ivi | Example: or a, MEM; | | | | Result: a ← a MEM | | | | Affected flags: "Y Z "N C "N AC "N OV | | | or M, a | Perform logic OR on ACC and memory, then put result into memory | | | <b>,</b> | Example: or MEM, a; | | | | Result: MEM ← a MEM | | | | Affected flags: "Y』Z "N』C "N』AC "N』OV | | | xor a, l | Perform logic XOR on ACC and immediate data, then put result into ACC | | | | Example: xor a, 0x0f; | | | | Result: a ← a ^ 0fh | | | | Affected flags: "Y Z "N C "N AC "N OV | | | xor IO, a Perform logic XOR on ACC and IO register, then put result into IO register | | | | | Example: xor pa, a; | | | | Result: pa ← a ^ pa ; // pa is the data register of port A | | | | Affected flags: 『N』Z 『N』C 『N』AC 『N』OV | | | xor a, M | Perform logic XOR on ACC and memory, then put result into ACC | | | | Example: xor a, MEM; | | | | Result: a ← a ^ RAM10 | | | | Affected flags: "Y Z "N C "N AC "N OV | | | xor M, a | Perform logic XOR on ACC and memory, then put result into memory | | | | Example: xor MEM, a; | | | | Result: MEM ← a ^ MEM | | | | Affected flags: "Y Z "N C "N AC "N OV | | | not a | Perform 1's complement (logical complement) of ACC | | | | Example: not a; | | | | Result: a ← ~a | | | | Affected flags: "Y Z "N C "N AC "N OV | | | | Application Example: | | | | | | | | mov a, 0x38; // ACC=0X38<br>not a; // ACC=0XC7 | |-----------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | not M | Perform 1's complement (logical complement) of memory Example: not MEM; Result: MEM ← ~MEM Affected flags: 『Y』Z 『N』C 『N』AC 『N』OV | | | Application Example: | | | mov a, 0x38; mov mem, a; // mem = 0x38 not mem; // mem = 0xC7 | | neg a | Perform 2's complement of ACC Example: neg a; Result: a ← 〒a Affected flags: 『Y』Z 『N』C 『N』AC 『N』OV | | | Application Example: | | neg M | Perform 2's complement of memory Example: neg MEM; Result: MEM ← 〒MEM Affected flags: 『Y』Z 『N』C 『N』AC 『N』OV Application Example: | | | mov a, 0x38; mov mem, a; // mem = 0x38 not mem; // mem = 0xC8 | | comp a, M | Compare ACC with the content of memory Example: comp a, MEM; Result: Flag will be changed by regarding as (a - MEM) Affected flags: 『Y』Z 『Y』C 『Y』AC 『Y』OV Application Example: | | | mov a, 0x38; mov mem, a; comp a, mem; // Z flag is set as 1 mov a, 0x42; mov mem, a; | | | mov a | , 0x38 ; | | | | |------------------|-------------------------------------------------------------------|-----------------|-------------------------------------------|--|--| | | comp a | , mem ; | // C flag is set as 1 | | | | comp M, a | Compare ACC with the content of memory | | | | | | 00111p 101, u | Example: comp | | • | | | | | · · · · · · · · · · · · · · · · · · · | | | | | | | | | ed by regarding as ( MEM - a ) | | | | | Affected flags: | YJZ | "Y_C "Y_AC "Y_OV | | | | 7.5. Bit Ope | ration Instructi | ons | | | | | set0 IO.n | Set bit n of IO po | rt to low | | | | | | Example: set0 pa.5; | | | | | | | Result: set bit 5 d | • | | | | | | | | 『N』C 『N』AC 『N』OV | | | | <i>set1</i> IO.n | Set bit n of IO po | • | | | | | | Example: set1 | • | - hinh | | | | | Result: set bit 5 | • | _ | | | | | | | "N_C "N_AC "N_OV | | | | swapc IO.n | Swap the nth bit | | • | | | | | Example: swapc IO.0; | | | | | | | Result: $C \leftarrow IO.0$ , $IO.0 \leftarrow C$ | | | | | | | When IO.0 is a port to output pin, carry C will be sent to IO.0; | | | | | | | When IO.0 is a port from input pin, IO.0 will be sent to carry C; | | | | | | | Affected flags: "N Z "Y C "N AC "N OV | | | | | | | Application Example1 (serial output) : | | | | | | | | | | | | | | set1 pa | ο O · | // set PA.0 as output | | | | | Seti pa | lC.U , | // Set PA.0 as output | | | | | set0 fla | g.1 ; | // C=0 | | | | | | g. ı ,<br>a.0 ; | // move C to PA.0 (bit operation), PA.0=0 | | | | | | | // C=1 | | | | | | - | // move C to PA.0 (bit operation), PA.0=1 | | | | | · · | a.u , | // move C to FA.0 (bit operation), FA.0-1 | | | | | | | | | | | | Application Example2 (serial input) : | | | | | | | | | | | | | | set0 p | ac.0 ; | // set PA.0 as input | | | | | | o 0 : | // road DA O to C (bit as a satism) | | | | | | a.0 ; | | | | | | src a | | // shift C to bit 7 of ACC | | | | | | a.0 ; | , , | | | | | src a | ; | // shift new C to bit 7, old C | | | | | | | | | | | | | | | | | | set0 M.n | Set bit n of memory to low | | | |----------------------------------|---------------------------------------|--|--| | | Example: set0 MEM.5; | | | | | Result: set bit 5 of MEM to low | | | | | Affected flags: 『N』Z 『N』C 『N』AC 『N』OV | | | | set1 M.n | Set bit n of memory to high | | | | | Example: set1 MEM.5; | | | | Result: set bit 5 of MEM to high | | | | | | Affected flags: 『N』Z 『N』C 『N』AC 『N』OV | | | ### 7.6. Conditional Operation Instructions | ceqsn a, I | Compare ACC with immediate data and skip next instruction if both are equal. | | | |---------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------|--|--| | 7 | Flag will be changed like as (a ← a − I) | | | | | Example: ceqsn a, 0x55; | | | | | inc MEM; | | | | | goto error; | | | | | Result: If a=0x55, then "goto error"; otherwise, "inc MEM". | | | | | Affected flags: "Y』Z "Y』C "Y』AC "Y』OV | | | | ceqsn a, M Compare ACC with memory and skip next instruction if both are equal. | | | | | · | Flag will be changed like as (a ← a - M) | | | | | Example: ceqsn a, MEM; | | | | | Result: If a=MEM, skip next instruction | | | | | Affected flags: "Y』Z "Y』C "Y』AC "Y』OV | | | | | | | | | cneqsn a, M | Compare ACC with memory and skip next instruction if both are not equal. | | | | | Flag will be changed like as (a ← a - M) | | | | | Example: cneqsn a, MEM; | | | | | Result: If a≠MEM, skip next instruction | | | | | Affected flags: "Y』Z "Y』C "Y』AC "Y』OV | | | | cneqsn a, l | Compare ACC with immediate data and skip next instruction if both are no equal. | | | | | Flag will be changed like as (a ← a - I) | | | | | Example: cneqsn a,0x55; | | | | | inc MEM; | | | | | goto error; | | | | | Result: If a≠0x55, then "goto error"; Otherwise, "inc MEM". | | | | | | | | | t0sn IO.n | Affected flags: "Y"Z "Y"C "Y"AC "Y"OV Check IO bit and skip next instruction if it's low | | | | 10311 10.11 | Example: t0sn pa.5; | | | | | Result: If bit 5 of port A is low, skip next instruction | | | | | Affected flags: "N Z "N Z "N AC "N OV | | | | t1sn IO.n | Check IO bit and skip next instruction if it's high | | | | | Example: t1sn pa.5; | | | | | | | | | | Result: If bit 5 of port A is high, skip next instruction | | | | | Result: If bit 5 of port A is high, skip next instruction Affected flags: "N』Z "N』C "N』AC "N』OV | | | | t0sn M.n | Result: If bit 5 of port A is high, skip next instruction Affected flags: 『N』Z 『N』C 『N』AC 『N』OV Check memory bit and skip next instruction if it's low | | | | t0sn M.n | Affected flags: 『N』Z 『N』C 『N』AC 『N』OV | | | | | AG 1 IG FN 7 FN 0 FN 00 FN 00 | |-----------------|--------------------------------------------------------------| | | Affected flags: 『N』Z 『N』C 『N』AC 『N』OV | | <i>t1sn</i> M.n | Check memory bit and skip next instruction if it's high | | | EX: t1sn MEM.5; | | | Result: If bit 5 of MEM is high, then skip next instruction | | | Affected flags: 『N』Z 『N』C 『N』AC 『N』OV | | izsn a | Increment ACC and skip next instruction if ACC is zero | | | Example: izsn a; | | | Result: a ← a + 1,skip next instruction if a = 0 | | | Affected flags: "Y』Z "Y』C "Y』AC "Y』OV | | dzsn a | Decrement ACC and skip next instruction if ACC is zero | | | Example: dzsn a; | | | Result: A ← A - 1,skip next instruction if a = 0 | | | Affected flags: "Y』Z "Y』C "Y』AC "Y』OV | | izsn M | Increment memory and skip next instruction if memory is zero | | | Example: izsn MEM; | | | Result: MEM ← MEM + 1, skip next instruction if MEM= 0 | | | Affected flags: "Y』Z "Y』C "Y』AC "Y』OV | | dzsn M | Decrement memory and skip next instruction if memory is zero | | | Example: dzsn MEM; | | | Result: MEM ← MEM - 1, skip next instruction if MEM = 0 | | | Affected flags: 『Y』Z 『Y』C 『Y』AC 『Y』OV | # 7.7. System Control Instructions | call label Function call, address can be full range address space Example: call function1; Result: [sp] ← pc + 1 pc ← function1 | | | | | | | |-------------------------------------------------------------------------------------------------------------------------------------|------------------|--|--|--|--|--| | Result: [sp] ← pc + 1<br>pc ← function1 | | | | | | | | pc ← function1 | | | | | | | | · | | | | | | | | | | | | | | | | $sp \leftarrow sp + 2$ | | | | | | | | Affected flags: 『N』Z 『N』C 『N』AC 『N』OV | | | | | | | | goto label Go to specific address which can be full range address space | | | | | | | | Example: <i>goto</i> error; | | | | | | | | Result: Go to error and execute program. | | | | | | | | Affected flags: 『N』Z 『N』C 『N』AC 『N』OV | | | | | | | | ret I Place immediate data to ACC, then return | | | | | | | | Example: ret 0x55; | | | | | | | | Result: A ← 55h | | | | | | | | ret; | | | | | | | | Affected flags: 『N』Z 『N』C 『N』AC 『N』OV | | | | | | | | ret Return to program which had function call | | | | | | | | Example: ret; | | | | | | | | Result: sp ← sp - 2 | | | | | | | | Pc ← [sp] | | | | | | | | Affected flags: 『N』Z 『N』C 『N』AC 『N』OV | | | | | | | | reti Return to program from interrupt service routine. After this command is | executed, global | | | | | | | interrupt is enabled automatically. | | | | | | | | Example: <i>reti</i> ; | | | | | | | | Affected flags: 『N』Z 『N』C 『N』AC 『N』OV | | | | | | | | nop No operation | | | | | | | | | Tyampla, nan | | | | | | | | |----------|----------------------------------------------------------------------------------------------------|--|--|--|--|--|--|--| | | Example: <i>nop</i> ; Result: nothing changed | | | | | | | | | | Affected flags: "N』Z "N』C "N』AC "N』OV | | | | | | | | | wdreset | | | | | | | | | | wareset | Reset Watchdog timer. Example: wdreset; | | | | | | | | | | Result: Reset Watchdog timer. | | | | | | | | | | Affected flags: "N Z "N C "N AC "N OV | | | | | | | | | pcadd a | Next program counter is current program counter plus ACC. | | | | | | | | | podda a | Example: pcadd a; | | | | | | | | | | Result: pc ← pc + a | | | | | | | | | | Affected flags: 『N』Z 『N』C 『N』AC 『N』OV | | | | | | | | | | Application Example: | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | mov a, 0x02 ; | | | | | | | | | | pcadd a; // PC <- PC+2 | | | | | | | | | | goto err1; | | | | | | | | | | goto correct; // jump here | | | | | | | | | | goto err2; | | | | | | | | | | goto err3; | | | | | | | | | | | | | | | | | | | | correct: // jump here | | | | | | | | | | | | | | | | | | | | | | | | | | | | | engint | Enable global interrupt enable | | | | | | | | | | Example: engint; | | | | | | | | | | Result: Interrupt request can be sent to FPP0 | | | | | | | | | disgint | Affected flags: 『N』Z 『N』C 『N』AC 『N』OV Disable global interrupt enable | | | | | | | | | uisgirit | Example: disgint; | | | | | | | | | | Result: Interrupt request is blocked from CPU | | | | | | | | | | Affected flags: "N Z "N C "N AC "N OV | | | | | | | | | stopsys | System halt. | | | | | | | | | σισρογο | Example: stopsys; | | | | | | | | | | Result: Stop the system clocks and halt the system | | | | | | | | | | Affected flags: 『N』Z 『N』C 『N』AC 『N』OV | | | | | | | | | stopexe | CPU halt. The oscillator module is still active to output clock, however, system clock is disabled | | | | | | | | | , | to save power. | | | | | | | | | | | | | | | | | | | | Example: stopexe; | | | | | | | | | | Result: Stop the system clocks and keep oscillator modules active. | | | | | | | | | root | Affected flags: 『N』Z 『N』C 『N』AC 『N』OV | | | | | | | | | reset | Reset the whole chip, its operation will be same as hardware reset. | | | | | | | | | | Example: reset; | | | | | | | | | | Result: Reset the whole chip. | | | | | | | | | | Affected flags: 『N』Z 『N』C 『N』AC 『N』OV | | | | | | | | # 7.8. Summary of Instructions Execution Cycle | 2T | | goto, call, idxm, pcadd, ret, reti | | | | | |----|----------------------------|---------------------------------------|--|--|--|--| | 2T | Condition is fulfilled | agger energy then then dran iron | | | | | | 1T | Condition is not fulfilled | ceqsn, cneqsn, t0sn, t1sn, dzsn, izsn | | | | | | 1T | | Others | | | | | ### 7.9. Summary of affected flags by Instructions | Instruction | Z | С | AC | ov | Instruction | Z | С | AC | ov | Instruction | Z | С | AC | ov | |-------------|---|---|----|----|-----------------|---|---|----|----|-------------------|---|---|----|----| | mov a, I | - | - | - | - | mov M, a | ı | ı | - | - | mov a, M | Υ | - | - | - | | mov a, IO | Υ | - | - | - | mov IO, a | - | - | - | - | <i>ldt16</i> word | - | - | - | - | | stt16 word | - | - | - | - | idxm a, index | - | - | - | - | idxm index, a | - | - | - | - | | xch M | - | - | - | - | pushaf | - | - | - | - | popaf | Υ | Υ | Υ | Υ | | add a, I | Υ | Υ | Υ | Υ | add a, M | Υ | Υ | Υ | Υ | add M, a | Υ | Υ | Υ | Υ | | addc a, M | Υ | Υ | Υ | Υ | addc M, a | Υ | Υ | Υ | Υ | addc a | Υ | Υ | Υ | Υ | | addc M | Υ | Υ | Υ | Υ | sub a, l | Υ | Υ | Υ | Υ | sub a, M | Υ | Υ | Υ | Υ | | sub M, a | Υ | Υ | Υ | Υ | subc a, M | Υ | Υ | Υ | Υ | subc M, a | Υ | Υ | Υ | Υ | | subc a | Υ | Υ | Υ | Υ | subc M | Υ | Υ | Υ | Υ | inc M | Υ | Υ | Υ | Υ | | dec M | Υ | Υ | Υ | Υ | clear M | - | - | - | - | sr a | - | Υ | - | - | | src a | - | Υ | - | - | sr M | - | Υ | - | - | src M | - | Υ | - | - | | sl a | - | Υ | - | - | slc a | - | Υ | - | - | s/ M | - | Υ | - | - | | slc M | - | Υ | - | - | swap a | - | - | - | - | and a, I | Υ | - | - | - | | and a, M | Υ | - | - | - | and M, a | Υ | - | - | - | or a, I | Υ | - | - | - | | or a, M | Υ | - | - | - | or M, a | Υ | - | - | - | xor a, l | Υ | - | - | - | | xor IO, a | - | - | - | - | xor a, M | Υ | - | - | - | xor M, a | Υ | - | - | - | | not a | Υ | - | - | - | not M | Υ | - | - | - | neg a | Υ | - | - | - | | neg M | Υ | - | - | - | set0 IO.n | - | - | - | - | set1 IO.n | - | - | - | - | | set0 M.n | - | - | - | - | set1 M.n | - | - | - | - | ceqsn a, I | Υ | Υ | Υ | Υ | | ceqsn a, M | Υ | Υ | Υ | Υ | t0sn IO.n | - | - | - | - | t1sn IO.n | - | - | - | - | | t0sn M.n | - | - | - | - | <i>t1sn</i> M.n | - | - | - | - | izsn a | Υ | Υ | Υ | Υ | | dzsn a | Υ | Υ | Υ | Υ | izsn M | Υ | Υ | Υ | Υ | dzsn M | Υ | Υ | Υ | Υ | | call label | - | - | - | - | goto label | - | - | - | - | ret I | - | - | - | - | | ret | - | - | - | - | reti | - | - | - | - | пор | - | - | - | - | | pcadd a | - | - | - | - | engint | - | - | - | - | disgint | - | - | - | - | | stopsys | - | - | - | - | stopexe | - | • | - | - | reset | - | - | - | - | | wdreset | - | - | - | - | nadd M, a | Υ | Υ | Υ | Υ | cneqsn a, I | Υ | Υ | Υ | Υ | | cneqsn a, M | Υ | Υ | Υ | Υ | comp a, M | Υ | Υ | Υ | Υ | nadd a, M | Υ | Υ | Υ | Υ | | comp M, a | Υ | Υ | Υ | Υ | swapc IO.n | - | Υ | - | - | | | | | | #### 7.10. BIT definition Bit access of RAM is only available for address from 0x00 to 0x3F. #### 8. Code Options | Option | Selection | Description | | | |------------------|-----------|-----------------------------------------------------------|--|--| | Socurity | Enable | OTP content is protected and program cannot be read back. | | | | Security | Disable | OTP content is not protected so program can be read back. | | | | LVR Reset filter | 11 | LVR Reset de-glitch is disable. | | | | | 10 | LVR Reset valid pulse width > 1 ILRC cycle (about 32us) | | | | | 01 | LVR Reset valid pulse width > 2 ILRC cycle (about 64us) | | | | | 00 | LVR Reset valid pulse width > 4 ILRC cycle (about 128us) | | | ### 9. Special Notes This chapter is intended to remind users of common mistakes to avoid when operating the PUD310 series ICs #### 9.1. Using IC #### 9.1.1. IO pin usage and setting - (1) IO pin is set to be digital input - ♦ When IO is set as digital input, the level of Vih and Vil would changes with the voltage and temperature. Please follow the minimum value of Vih and the maximum value of Vil. - ◆ The value of internal pull high resistor would also change with the voltage, temperature and pin voltage. It is not the fixed value. - (2) IO pin as digital input and enable wakeup function - ◆ Configure IO pin as input - ◆ Set corresponding bit to "1" in PXDIER - ◆ The IO toggle width must be more than one system clock cycle. - (3) PA7 is set to be output pin - ◆ PA7 can be set to be Open-Drain output pin only, output high requires adding pull-high resistor. - (4) PA5 is set to be PRSTB input pin - ◆ Configure PA5 as input - ◆ Set RSTC.0=1 to enable PA5 as PRSTB input pin **Note:** Please read the PMC-APN013 carefully. According to PMC-APN013, the crystal oscillator should be used reasonably. If the following situations happen to cause IC start-up slowly or non-startup, PADAUK Technology is not responsible for this: the quality of the user's crystal oscillator is not good, the usage conditions are unreasonable, the PCB cleaner leakage current, or the PCB layouts are unreasonable. #### 9.1.2. Interrupt (1) When using the interrupt function, the procedure should be: Step1: Set INTEN register, enable the interrupt control bit Step2: Clear INTRQ register Step3: In the main program, using ENGINT to enable CPU interrupt function Step4: Wait for interrupt. When interrupt occurs, enter to Interrupt Service Routine Step5: After the Interrupt Service Routine being executed, return to the main program \*Use DISGINT in the main program to disable all interrupts \*When interrupt service routine starts, use PUSHAF instruction to save ALU and FLAG register. POPAF instruction is to restore ALU and FLAG register before RETI as below: (2) INTEN and INTRQ have no initial values. Please set required value before enabling interrupt function. #### 9.1.3. System clock switching System clock can be switched by CLKMD register. Please notice that, NEVER switch the system clock and turn off the original clock source at the same time. For example: When switching from clock A to clock B, please switch to clock B first; and after that turn off the clock A oscillator through CLKMD. ``` ◆ Example: Switch system clock from IHRC to ILRC CLKMD = 0x02; // switch to ILRC, IHRC can not be disabled here CLKMD.1 = 0; // IHRC can be disabled at this time • EPPOP: Switch IHRC to ILRC and turn off IHRC simultaneously ``` ♦ ERROR: Switch IHRC to ILRC and turn off IHRC simultaneously CLKMD = 0x00; // MCU will hang #### 9.1.4. Watchdog Watchdog is open by default, but when the program executes ADJUST\_IC, the watchdog will be closed. To use the watchdog, you need to reconfigure the open. Watchdog will be inactive once ILRC is disabled. #### 9.1.5. TIMER time out When select \$ INTEGS BIT\_R (default value) and T16M counter BIT8 to generate interrupt, if T16M counts from 0, the first interrupt will occur when the counter reaches to 0x100 (BIT8 from 0 to 1) and the second interrupt will occur when the counter reaches 0x300 (BIT8 from 0 to 1). Therefore, selecting BIT8 as 1 to generate interrupt means that the interrupt occurs every 512 counts. Please notice that if T16M counter is restarted, the next interrupt will occur once Bit8 turns from 0 to 1. If select \$ INTEGS BIT\_F(BIT triggers from 1 to 0) and T16M counter BIT8 to generate interrupt, the T16M counter changes to an interrupt every 0x200/0x400/0x600/. Please pay attention to two differences with setting INTEGS methods. #### 9.1.6. IHRC - (1) The IHRC frequency calibration is performed when IC is programmed by the writer. - (2) Because the characteristic of the Epoxy Molding Compound (EMC) would some degrees affects the IHRC frequency (either for package or COB), if the calibration is done before molding process, the actual IHRC frequency after molding may be deviated or becomes out of spec. Normally, the frequency is getting slower a bit. - (3) It usually happens in COB package or Quick Turnover Programming (QTP). And PADAUK would not take any responsibility for this situation. - (4) Users can make some compensatory adjustments according to their own experiences. For example, users can set IHRC frequency to be 0.5% ~ 1% higher and aim to get better re-targeting after molding. #### 9.1.7. LVR LVR level selection is done at compile time. User must select LVR based on the system working frequency and power supply voltage to make the MCU work stably. The following are Suggestions for setting operating frequency, power supply voltage and LVR level: | SYSCLK | VDD | LVR | Temp. | |--------|--------|--------|-------| | 1.5MHz | ≥ 1.8V | ≥ 1.8V | | | 3MHz | ≥ 2.0V | ≥ 2.0V | 0=00 | | 6MHz | ≥ 2.0V | ≥ 2.0V | 25℃ | | 12MHz | ≥ 2.3V | ≥ 2.3V | | - (1) The setting of LVR (1.8V ~ 4.5V) will be valid just after successful power-on process. - (2) User can set MISC2.4 as "0" to disable LVR. However, VDD must be kept as exceeding the lowest working voltage of chip; Otherwise IC may work abnormally. - (3) The LVR function will be invalid when IC in stopexe or stopsys mode. #### 9.1.8. Programming Writing There are 4 pins for using the writer to program: DP(PA4), DM(PA6), VDD and GND. Please use 5S-P-003x or later version to program PUD310 real chip. (3S-P-002 or elder versions do not support programming PUD310) - Special notes about voltage and current while Multi-Chip-Package (MCP) or On-Board Programming - (1) VDD⊤ may be higher than 9.5V, and its maximum current may reach about 20mA. - (2) All other signal pins level (except GND) are the same as VDD<sub>T</sub>. User should confirm when using this product in MCP or On-Board Programming, the peripheral components or circuit will not be damaged by the above voltages, and will not clam the above voltages. #### Important Cautions: - You MUST follow the instructions on APN004 and APN011 for programming IC on the handler. - Connecting a 0.01uF capacitor between V<sub>BAT</sub> and GND at the handler port to the IC is always good for suppressing disturbance. But please DO NOT connect with > 0.01uF capacitor, otherwise, programming may be fail. For 5S-P-003x to write PUD310, use jumper7 to adapt program signal connection. The connection of signal depends on the IC package. Please refer to. Chapter 5 of the Writer user manual to find example and make the jumper-7 adaptive board for target IC package. User can get the user manual from the following linker web page. http://www.padauk.com.tw/en/technical/index.aspx?kind=27 for example, make JP7 writer signal connection of ESSOP-10, as the following. Fig. 9.1: schematic diagram of Jumper7 for P-003x Load PDK from GUI, insert JP7 and then input IC on the socket without shift. After LCDM displays IC ready, it can be written.